新秀建站教程

Typecho加密文章的Html结构自定义代码

Html.jpg


为什么要自定义

我们先看下正常的typecho加密文章的html代码结构

<form class="protected" action="一个链接地址" method="post">
<p class="word">请输入密码访问</p>
<p>
<input type="password" class="text" name="protectPassword">
<input type="hidden" name="protectCID" value="文章id">
<input type="submit" class="submit" value="提交">
</p>
</form>

那么我们作为模板的作者,如果要写这部分的样式,就必须根据他的class来写样式;
但是如果我用的是前端框架,框架已经内置好了一些表单样式,我们为什么不用呢?

因为typecho默认的结构,无法套用,所以就有了这篇文章。

自定义加密文章的Html

将模板post.php中的<?php $this->content(); ?>换为以下代码即可,其中html结构可根据自己模板架构自行调整。

<!--判断文章是否加密-->
<?php if($this->hidden||$this->titleshow): ?>
<!--如果加密,输出自定义的表单格式-->
<form action="<?php echo Typecho_Widget::widget('Widget_Security')->getTokenUrl($this->permalink); ?>" method="post">
<div class="form-group mb-3">
<label>请输入密码访问</label>
<div class="input-group">
<input  type="password" class="text" name="protectPassword" class="form-control" placeholder="请输入密码" aria-label="请输入密码">
<input type="hidden" name="protectCID" value="<?php $this->cid(); ?>" />
<div class="input-group-append">
<button class="btn btn-primary" type="submit">提交</button>
</div>
</div>
</div>
</form>
<?php else: ?>
<!--如果未加密,输出文章内容-->
<?php $this->content(); ?>
<?php endif;?>

其中$this->titleshow是用来兼容titleshow插件的。


关于Titleshow插件

Typecho文章密码保护功能,默认会强制标题为”此内容被密码保护“,隐藏文章标签,强制文章评论数为0,隐藏文章内容,并且不允许文章进行评论,还会返回403
Titleshow插件,完美的解决了这些问题,加密文章可以显示标题,允许评论,不返回403状态等等,让文章加密功能只加密文章内容不影响其他。
那么,这么好的插件去哪里下载呢?
点我下载插件


原文地址:https://www.mantouxia.com/go/Html-jm/

原创文章,作者:馒头侠,如若转载,请注明出处:https://www.mantouxia.com/147.html
typecho图片压缩上传插件MyUpload,支持TinyPNG
« 上一篇 01-05
typecho大方、简洁的相册主题-Photograph
下一篇 » 01-06

发表评论