MENU

Typecho教程 - 非插件实现回复可见

• March 1, 2020 • 教程

前言

这个教程网上很多的,包括我也是从网上搬来的,但是网上的涉及文件太多,这里给大家推荐我修改的方法,希望能帮助到大家。
首先我们进入 /网站根目录/usr/themes/{主题名} ,然后按照下面的文件来修改。

post.php文件

这里我们是依照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()); ?>

functions.php文件

//找一处风水宝地,添加下面的代码
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;
    }
}

header.php文件

<!-- 在head标签中添加回复可见的样式 -->
<style>
.reply2view {
    background:#f8f8f8;
    border-radius:5px;
    border:1px dashed #888888;
    padding:10px 10px 10px 40px;
    position:relative;
}
</style>

大功告成

划重点:一定要去掉@才可以用,这里加@是防止被替换成隐藏内容

[@hide]要隐藏的内容[/hide]

这样修改的话既方便后期维护,也方便随时更改,同时也可以解决文章列表暴露隐藏内容的风险。
回复可见的样式是按照我的喜好来写的,你们要是不喜欢的话可以换成别的样式。

2020年03月17日补充

感觉加一下半透明会好看一点,所以说改了一下子样式

<!-- 带有半透明效果的样式 -->
<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>
Last Modified: May 26, 2020
Archives 下载海报
QR Code for this page
Tipping QR Code
Leave a Comment

已有 1 条评论
  1. adu

    Cuckoo 模板找不到那句代码啊?