• 欢迎访问尽管叫我疯子的网站,WordPress信息,WordPress教程,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站 QQ群
  • Git主题现已支持滚动公告栏功能,兼容其他浏览器,看到的就是咯,在后台最新消息那里用li标签添加即可。

WordPress中展示浏览量的几种方法

WP帮助文档 hucong 1年前 (2018-07-12) 359次浏览 0个评论

方法一  利用插件 WP-PostViews 显示

 

首先安装 WP-PostViews,然后进行设置

后台管理页面->设置(Setting)->PostViewers

  1. 将统计权限设置所有人(Everyone)
  2. 显示格式设置为中文格式 %S 次浏览

格式如下,然后应用,此时刷新主站点默认还是不显示,还得在主题的配置文件中进行相应的修改才行

修改主题配置文件

还是以当前主题 zerif-lite 为例,进入到主题目录下

/home/www/htdocs/wp-content/themes/zerif-lite

将需要修改的几个文件 archive.php、index.php、page.php 和 single.php 拖到本地来
在每个 php 文件的 loop 循环中(即方括号区域)插入显示浏览量的代码 the_views();

if(function_exists('the_views')) { the_views(); }


然后保存后上传回主题目录下覆盖源文件,此时刷新站点,即可查看到浏览量信息

进阶

这里只是简单介绍下文章浏览量的显示,网上还有很多进阶的应用,如显示最热文章、自定义显示等,都是基于调用 the_viewers 函数,详情可以参考别人的博客
WP-PostViews 浏览次数统计插件使用详解

二.使用纯代码实现浏览量的显示

前言

WordPress 非插件实现文章浏览次数统计的方法,是 DH 参考 willin kan 大师的 my_visitor 插件来写的,刷新一次文章页面就统计一次,比较简单实用。

添加自定义函数到主题下的 functions.php 中

在主题的 php 文件的最后一个 ?> 前面添加下面的代码:

/* 访问计数 */
function record_visitors()
{
if (is_singular())
{
global $post;
$post_ID = $post->ID;
if($post_ID)
{
$post_views = (int)get_post_meta($post_ID, 'views', true);
if(!update_post_meta($post_ID, 'views', ($post_views+1)))
{
add_post_meta($post_ID, 'views', 1, true);
}
}
}
}
add_action('wp_head', 'record_visitors');

/// 函数名称:post_views
/// 函数作用:取得文章的阅读次数
function post_views($before = '(点击 ', $after = ' 次)', $echo = 1)
{
global $post;
$post_ID = $post->ID;
$views = (int)get_post_meta($post_ID, 'views', true);
if ($echo) echo $before, number_format($views), $after;
else return $views;
}

在需要显示该统计次数的地方使用下面的代码调用:

进阶:获取浏览次数最多的文章

如果要获取上面的函数统计出来的浏览次数最多的文章,可以在 functions.php 文件的最后一个 ?> 前面添加下面的代码:

/// get_most_viewed_format
/// 函数作用:取得阅读最多的文章
function get_most_viewed_format($mode = '', $limit = 10, $show_date = 0, $term_id = 0, $beforetitle= '(', $aftertitle = ')', $beforedate= '(', $afterdate = ')', $beforecount= '(', $aftercount = ')') {
global $wpdb, $post;
$output = '';
$mode = ($mode == '') ? 'post' : $mode;
$type_sql = ($mode != 'both') ? "AND post_type='$mode'" : '';
$term_sql = (is_array($term_id)) ? "AND $wpdb->term_taxonomy.term_id IN (" . join(',', $term_id) . ')' : ($term_id != 0 ? "AND $wpdb->term_taxonomy.term_id = $term_id" : '');
$term_sql.= $term_id ? " AND $wpdb->term_taxonomy.taxonomy != 'link_category'" : '';
$inr_join = $term_id ? "INNER JOIN $wpdb->term_relationships ON ($wpdb->posts.ID = $wpdb->term_relationships.object_id) INNER JOIN $wpdb->term_taxonomy ON ($wpdb->term_relationships.term_taxonomy_id = $wpdb->term_taxonomy.term_taxonomy_id)" : '';

// database query
$most_viewed = $wpdb->get_results("SELECT ID, post_date, post_title, (meta_value+0) AS views FROM $wpdb->posts LEFT JOIN $wpdb->postmeta ON ($wpdb->posts.ID = $wpdb->postmeta.post_id) $inr_join WHERE post_status = 'publish' AND post_password = '' $term_sql $type_sql AND meta_key = 'views' GROUP BY ID ORDER BY views DESC LIMIT $limit");
if ($most_viewed) {
foreach ($most_viewed as $viewed) {
$post_ID    = $viewed->ID;
$post_views = number_format($viewed->views);
$post_title = esc_attr($viewed->post_title);
$get_permalink = esc_attr(get_permalink($post_ID));
$output .= "<li>$beforetitle$post_title$aftertitle";
if ($show_date) {
$posted = date(get_option('date_format'), strtotime($viewed->post_date));
$output .= "$beforedate $posted $afterdate";
}
$output .= "$beforecount $post_views $aftercount</li>";
}
} else {
$output = "<li>N/A</li>n";
}
echo $output;
}

然后使用下面的函数调用:

注:
1.php 中允许没有结束符’?>’,所以直接在最后面插入代码即可
2.编辑 WordPress 主题的 php 文件的注意事项

引用文章
1.WP-PostViews 浏览次数统计插件使用详解
2.WordPress 非插件添加文章浏览次数统计功能
3.WordPress 添加 WP-PostViews 插件显示访问量


尽管叫我疯子 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:WordPress 中展示浏览量的几种方法
喜欢 (0)
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址