这个教程网上很多的,包括我也是从网上搬来的,但是网上的涉及文件太多,这里给大家推荐我修改的方法,希望能帮助到大家。 首先我们进入 /网站根目录/usr/themes/{主题名} ,然后按照下面的文件来修改。
这里我们是依照Cuckoo模板来修改的,大家可以根据自己的情况来修改。
//找到
<?php parsePicture(parseBiaoQing($this->content())); ?>
//修改成
<?php echo parse_content(parsePicture(parseBiaoQing($this->content)),$this->cid,$this->remember('mail',true),$this->user->hasLogin()); ?>
2020-04-01更新,Cuckoo迎来了1.0.3,新版本的回复可见应该是:
//找到
<?php parseContent(parseBiaoQing($this->content())); ?>
//修改成
<?php echo parse_content(parseContent(parseBiaoQing($this->content)),$this->cid,$this->remember('mail',true),$this->user->hasLogin()); ?>
其他的模板应该是
//找到
<?php $this->content(); ?>
//修改成
<?php echo parse_content($this->content,$this->cid,$this->remember('mail',true),$this->user->hasLogin()); ?>
//找一处风水宝地,添加下面的代码
function parse_content($content,$cid,$mail,$login){
$db = Typecho_Db::get();
$sql = $db->select()->from('table.comments')
->where('cid = ?',$cid)
->where('mail = ?', $mail)
->where('status = ?', 'approved')
->limit(1);
$result = $db->fetchAll($sql);
if($login || $result) {
$content = preg_replace("/\[hide\](.*?)\[\/hide\]/sm",'$1',$content);
}
else{
$content = preg_replace("/\[hide\](.*?)\[\/hide\]/sm",'<div class="reply2view">您需要<a href="/admin/login.php">登录</a>或者<a onclick="window.scrollTo(0, document.documentElement.clientHeight);">回复</a>才能显示此处隐藏内容。</div>',$content);
}
return $content;
}
Typecho_Plugin::factory('Widget_Abstract_Contents')->excerptEx = array('moleft','one');
Typecho_Plugin::factory('Widget_Abstract_Contents')->contentEx = array('moleft','one');
class moleft {
public static function one($con,$obj,$text)
{
$text = empty($text)?$con:$text;
if(!$obj->is('single')){
$text = preg_replace("/\[hide\](.*?)\[\/hide\]/sm",'此处内容已隐藏',$text);
}
return $text;
}
}
<!-- 在head标签中添加回复可见的样式 -->
<style>
.reply2view {
background:#f8f8f8;
border-radius:5px;
border:1px dashed #888888;
padding:10px 10px 10px 40px;
position:relative;
}
</style>
划重点:一定要去掉@才可以用,这里加@是防止被替换成隐藏内容
[@hide]要隐藏的内容[/hide]
这样修改的话既方便后期维护,也方便随时更改,同时也可以解决文章列表暴露隐藏内容的风险。 回复可见的样式是按照我的喜好来写的,你们要是不喜欢的话可以换成别的样式。
感觉加一下半透明会好看一点,所以说改了一下子样式
<!-- 带有半透明效果的样式 -->
<style>
.reply2view {
background-color:rgb(255,255,255,0.3);
border-radius:5px;
border:1px dashed #888888;
padding:10px 10px 10px 40px;
position:relative;
}
</style>
如无特殊说明《Typecho教程 - 非插件实现回复可见》为博主MoLeft原创,转载请注明原文链接为:https://moleft.cn/post-22.html