本文转载自 typecho 非插件实现文章阅读次数统计 (cookie 版)

介绍

这个版本的代码,不会刷新一次就多一次浏览器数的,更具有真实性

function.php 引入代码

function get_post_view($archive)
{
    $cid    = $archive->cid;
    $db     = Typecho_Db::get();
    $prefix = $db->getPrefix();
    if (!array_key_exists('views', $db->fetchRow($db->select()->from('table.contents')))) {
        $db->query('ALTER TABLE `' . $prefix . 'contents` ADD `views` INT(10) DEFAULT 0;');
        echo 0;
        return;
    }
    $row = $db->fetchRow($db->select('views')->from('table.contents')->where('cid = ?', $cid));
    if ($archive->is('single')) {
 $views = Typecho_Cookie::get('extend_contents_views');
        if(empty($views)){
            $views = array();
        }else{
            $views = explode(',', $views);
        }
if(!in_array($cid,$views)){
       $db->query($db->update('table.contents')->rows(array('views' => (int) $row['views'] + 1))->where('cid = ?', $cid));
array_push($views, $cid);
            $views = implode(',', $views);
            Typecho_Cookie::set('extend_contents_views', $views); //记录查看cookie
        }
    }
    echo $row['views'];
}

在需要的地方引入代码

<?php get_post_view($this) ?>
比如我放在了 post.php 中,我是这样写得多

<span class="view-times"><?php get_post_view($this) ?>次围观</span>

我加了点css

span.view-times::before {
    font: normal normal normal 12px/1 FontAwesome;
    content: "\f06e";
    margin-right: 3px;
}

这样效果就和本博客效果一样了,前提是引入font-awesome的css

最后修改:2019 年 02 月 26 日
喜欢我的文章吗?
别忘了点赞或赞赏,让我知道创作的路上有你陪伴。