f
wordpress非插件添加文章浏览次数统计功能并获取最热文章
wordpress非插件添加文章浏览次数统计功能并获取最热文章
二呆 7年前 (2017-09-02) wordpress优化  #wordpress# 
浏览:4803

引言:此文由子域名转移而来,因为细微强迫症和放弃子域名而不舍得完全丢弃,所以将会逐步第二次转移文章到主域名上来,二者主题(阿里白秀和D8)均来自大前端,追求完美的同时有一丝小懒,主题就不换了,D8主题用起来挺好。

在wordpress主题中有不少都用到了wp-postviews插件,它可以统计文章的浏览次数,但对于一些站长不喜欢用太多的插件,能不用就不用,这也是为了加速wordpress程序,所以有必要分享wordpress非插件添加文章浏览次数统计功能。

另外,如果想下载wp-postviews插件可以直接在wordpress后台安装插件处搜索wp-postviews,即可安装成功。

(点击这里查看原文)

非插件统计文章浏览次数——方法一

1、将以下代码插入function.php中。

  1. /* 访问计数 */
  2. function record_visitors(){
  3.     if (is_singular()){
  4.         global $post;
  5.         $post_ID = $post->ID;
  6.         if($post_ID){
  7.             $post_views = (int)get_post_meta($post_ID, 'views', true);
  8.             if(!update_post_meta($post_ID, 'views', ($post_views+1))){
  9.                 add_post_meta($post_ID, 'views', 1, true);
  10.             }
  11.         }
  12.     }
  13. }
  14. add_action('wp_head', 'record_visitors');
  15. //函数名称:post_views
  16. //函数作用:取得文章的阅读次数
  17. function post_views($before = '(点击 ', $after = ' 次)', $echo = 1){
  18.     global $post;
  19.     $post_ID = $post->ID;
  20.     $views = (int)get_post_meta($post_ID, 'views', true);
  21.     if ($echoecho $before, number_format($views), $after;
  22.     else return $views;
  23. }

2、在需要添加浏览次数的地方添加如下代码即可。

  1. <?php post_views(' ', ' 次'); ?>

非插件统计文章浏览次数——方法二

 

1、同样,将如下代码插入到function.php中。

  1. /* Postviews start */
  2. function getPostViews($postID){
  3.     $count_key = 'post_views_count';
  4.     $count = get_post_meta($postID$count_key, true);
  5.     if($count==){
  6.         delete_post_meta($postID$count_key);
  7.         add_post_meta($postID$count_key, '0');
  8.         return " 0 ";
  9.     }
  10.     return $count;
  11. }
  12. function setPostViews($postID) {
  13.     $count_key = 'post_views_count';
  14.     $count = get_post_meta($postID$count_key, true);
  15.     if($count==){
  16.         $count = 0;
  17.         delete_post_meta($postID$count_key);
  18.         add_post_meta($postID$count_key, '0');
  19.     }else{
  20.         $count++;
  21.         update_post_meta($postID$count_key$count);
  22.     }
  23. }
  24. /* Postviews start end*/

2、功能代码添加好后,我们开始进行统计,在single.php中的 endwhile; endif;  循环前添加如下代码:

  1. <?php setPostViews(get_the_ID());?>

3、最后就可以在需要统计次数的地方添加如下代码了。

  1. <?php echo getPostViews(get_the_ID()); ?> 次浏览

获取浏览次数最多的文章

 

1、将以下代码插入到function.php中。

  1. //get_most_viewed_format函数作用:取得阅读最多的文章
  2. function get_most_viewed_format($mode = $limit = 10, $show_date = 0, $term_id = 0, $beforetitle= '(', $aftertitle = ')', $beforedate= '(', $afterdate = ')', $beforecount= '(', $aftercount = ')') {
  3.     global $wpdb$post;
  4.     $output = ;
  5.     $mode = ($mode == ) ? 'post' : $mode;
  6.     $type_sql = ($mode != 'both') ? "AND post_type='$mode'" : ;
  7.     $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" : );
  8.     $term_sql.= $term_id ? " AND $wpdb->term_taxonomy.taxonomy != 'link_category'" : ;
  9.     $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)" : ;
  10.     // database query
  11.     $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");
  12.     if ($most_viewed) {
  13.         foreach ($most_viewed as $viewed) {
  14.             $post_ID    = $viewed->ID;
  15.             $post_views = number_format($viewed->views);
  16.             $post_title = esc_attr($viewed->post_title);
  17.             $get_permalink = esc_attr(get_permalink($post_ID));
  18.             $output .= "<li>$beforetitle$post_title$aftertitle";
  19.             if ($show_date) {
  20.                 $posted = date(get_option('date_format'), strtotime($viewed->post_date));
  21.                 $output .= "$beforedate $posted $afterdate";
  22.             }
  23.             $output .= "$beforecount $post_views $aftercount</li>";
  24.         }
  25.     } else {
  26.         $output = "<li>N/A</li>n";
  27.     }
  28.     echo $output;
  29. }

2、在需要显示浏览次数最多的文章列表的地方插入如下代码即可。

  1. <?php get_most_viewed_format(); ?>

推荐阅读
  • 以下仅供学习使用以及纪念之用,已过时,将不再继续鼓捣,请知悉。因能力有限,将它们弄出来后修改时都得调试半天,日后随缘上香。任何事物的成长都需要沉淀,不然就会成以下这些一样的结果。继续在另一个条漫长的转型不归路上走着…走着……以下仍然可以站内搜索相关简介:001、DNSP...
  • 插件截图:插件简介:TleUCenterForWordpress是一个用户中心插件,放置于前台网页的左下角,供用户登陆/管理只用,使用邮箱验证码登陆,登陆之后在使用TleWeiboForWordPressV2.0微博主题的情况下,可以显示微博列表、文章列表、评论列表,也可...
  • 插件截图:插件介绍:TleLiveCtrlForWordpress是一个基于Kplayer的直播遥控器插件,也可以叫做KplayerForWordPress插件,支持多平台直播推流,进行积分点播、查询、跳过等功能,支持Payjs微信、支付宝支付,是一个可以24小时直播推流的...
  • 主题截图:主题简介:一款Wordpress版本的TleWeiboForWordPress电脑/手机版微博主题使用方法:将本主题里的所有文件放在您网站目录的wp-content/themes内,注意文件夹名字必须为TleWeibo或TleWeiboWap。...
  • 插件简介:即时聊天插件为WordPress站长及用户提供即时聊天功能,前台环信即时聊天需要配合个人中心插件,暂不支持手机端。在支持手机端的路上,因为万恶的360网站卫士最近访问困难,导致停留了N久,最后啥也没动,就升级至V1.0.10了,不过仅仅支持了简单的手机端版本。使...

o p
Ú
>