本文转载自 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 日
喜欢我的文章吗?
别忘了点赞或赞赏,让我知道创作的路上有你陪伴。