WordPress侧边栏如何添加站点统计信息?

我们建立站点有一段时间之后,就想在侧边栏显示我们站点的相关统计信息,比如站点已经运行多少天、发布了多少篇文章、有多少条评论,有多少阅读量等等。但是WordPress自身是不带有这个功能的,所以需要我们自己注册一个站点统计小工具,然后通过后台 >> 外观 >> 小工具 >> 找到站点统计小工具,然后添加到相应的侧边栏即可。

站点统计小工具实现办法

1、新建一个sidebar_tongji.php文件,并将以下代码添加到sidebar_tongji.php文件中。或者点此直接下载sidebar_tongji.php文件(密码:dyme)。

<?php

// 站点统计小工具
// 代码来自网络,版权无从考究


// 定义小工具的类 EfanBlogStat
class EfanBlogStat extends WP_Widget{

	function EfanBlogStat(){
		// 定义小工具的构造函数
		$widget_ops = array('classname' => 'widget_blogstat', 'description' => '显示站点的统计信息');
		$this->WP_Widget(false, '站点统计', $widget_ops);
	}
	
	function form($instance){
		// 表单函数,控制后台显示
		// $instance 为之前保存过的数据
		// 如果之前没有数据的话,设置默认量
		$instance = wp_parse_args(
			(array)$instance,
			array(
				'title' => '站点统计',
				'establish_time' => '2018-01-01'
			)
		);

		$title = htmlspecialchars($instance['title']);
		$establish_time = htmlspecialchars($instance['establish_time']);
		
		
		// 表格布局输出表单
		$output = '<table>';
		$output .= '<tr><td>标题</td><td>';
		$output .= '<input id="'.$this->get_field_id('title') .'" name="'.$this->get_field_name('title').'" type="text" value="'.$instance['title'].'" />';
		$output .= '</td></tr><tr><td>建站日期:</td><td>';   
		$output .= '<input id="'.$this->get_field_id('establish_time') .'" name="'.$this->get_field_name('establish_time').'" type="text" value="'.$instance['establish_time'].'" />';   
		$output .= '</td></tr></table>';  
		
		echo $output;   
	}
	
	function update($new_instance, $old_instance){
		// 更新数据的函数
		$instance = $old_instance;
		// 数据处理
		$instance['title'] = strip_tags(stripslashes($new_instance['title']));
		$instance['establish_time'] = strip_tags(stripslashes($new_instance['establish_time']));

		return $instance;
	}
	
	function widget($args, $instance){
		extract($args); //展开数组
		$title = apply_filters('widget_title',empty($instance['title']) ? '&nbsp;' : $instance['title']);
		$establish_time = empty($instance['establish_time']) ? '2018-01-01' : $instance['establish_time'];
		echo $before_widget;
		echo $before_title . $title . $after_title;
		echo '<ul>';
		// $this->efan_get_blogstat($establish_time, $instance);
		$this->efan_get_blogstat($establish_time);
		echo '</ul>';
		echo $after_widget;
	}
	
	function efan_get_blogstat($establish_time /*, $instance */){
		// 相关数据的获取
		global $wpdb;
		$count_posts = wp_count_posts();
		$published_posts = $count_posts->publish;
		$comments_count = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->comments");
		$time = floor((time()-strtotime($establish_time))/86400);
		$count_tags = wp_count_terms('post_tag');
		$count_pages = wp_count_posts('page');
		$page_posts = $count_pages->publish;
		$count_categories = wp_count_terms('category'); 
		$link = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->links WHERE link_visible = 'Y'"); 
		$last = $wpdb->get_results("SELECT MAX(post_modified) AS MAX_m FROM $wpdb->posts WHERE (post_type = 'post' OR post_type = 'page') AND (post_status = 'publish' OR post_status = 'private')");
		$last = date('Y-n-j', strtotime($last[0]->MAX_m));
		$total_views = $wpdb->get_var("SELECT SUM(meta_value+0) FROM $wpdb->postmeta WHERE meta_key = 'views'");  
		// 显示数据

		$output = '<li>日志总数:';
		$output .= $published_posts;
		$output .= ' 篇</li>';
		$output .= '<li>评论数目:';
		$output .= $comments_count;
		$output .= ' 条</li>';
		$output .= '<li>页面总数:';
		$output .= $page_posts;
		$output .= ' 个</li>';
		$output .= '<li>分类总数:';
		$output .= $count_categories;
		$output .= ' 个</li>';
		$output .= '<li>标签总数:';
		$output .= $count_tags;
		$output .= ' 个</li>';
		$output .= '<li>友链总数:';
		$output .= $link;
		$output .= ' 个</li>';
		$output .= '<li>浏览次数:';
		$output .= $total_views;
		$output .= ' 次</li>';
		$output .= '<li>建站日期:';
		$output .= $establish_time;
		$output .= '</li>';
		$output .= '<li>运行天数:';
		$output .= $time;
		$output .= ' 天</li>';
		$output .= '<li>最后更新:';
		$output .= $last;
		$output .= '</li>';
		
		echo $output;
	}
}

function EfanBlogStat(){
	// 注册小工具
	register_widget('EfanBlogStat');
}

add_action('widgets_init','EfanBlogStat');

?>

2、将步骤1的sidebar_tongji.php文件上传到当前主题文件夹内,并在当前主题的functions.php文件最后一个?>的前面添加一下代码

//添加站点统计小工具文件
include("sidebar_tongji.php");

请注意:如果sidebar_tongji.php文件不是放在根目录,那么第2步引用sidebar_tongji.php文件的路径就要做相应调整才行。比如是存放在主题文件的inc文件夹内,那么就应该是:

//添加站点统计小工具文件
include("sidebar_tongji.php");

具体效果如下:

如何输出自定义类型文章的所有分类和所有标签?

昨天我们介绍了WordPress站点如何添加自定义类型文章、分类和标签?,既然已经为我们的自定义类型文章添加了分类和标签,那么如果我们想在某个地方输出某个自定义类型文章的所有分类或者所有标签又应该怎么做呢?

其实这个问题还是挺简单的,我们以昨天那篇添加自定义类型文章的分类和标签为例进行说明。

1、显示自定义类型文章的所有分类:

只需要在需要显示某个自定义类型文章的所有分类处添加以下代码即可:

<?php
	$terms = get_terms("taobao");
	$count = count($terms);
	if ( $count > 0 ){
		foreach ( $terms as $term ) {
			echo '<a href="' . get_term_link( $term ) . '" target="_blank" rel="tag">' . $term->name . '</a>';
		}
	}
?>

2、显示自定义类型文章的所有标签:

只需要在需要显示某个自定义类型文章的所有标签处添加以下代码即可:

<?php
	$terms = get_terms("taotag");
	$count = count($terms);
	if ( $count > 0 ){
		foreach ( $terms as $term ) {
			echo '<a href="' . get_term_link( $term ) . '" target="_blank" rel="tag">' . $term->name . '</a>';
		}
	}
?>

温馨提示:大家记得修改以上代码的taobao或taotag为自己站点的自定义类型文章分类和标签相对应的slug,要不然会出错哦。至于输出的具体样式就需要大家自行调整添加了。

WordPress站点如何添加自定义类型文章、分类和标签?

网上大部分人分享添加WordPress自定义类型文章的代码,一般都是包含了文章和分类,最多就是添加一个跟文章类型post共用一个标签库,但是默认标签库的数量是增加了,但是点击查看该标签文章却没有那么多,只能看到post类型的文章,而看不到自定义文章类型,所以最好的方案就是为自定义类型的文章弄一个独立的标签库。

将以下代码添加到当前主题的functions.php文件中,或者添加到一个文章类型的post_type.php文件,然后在functions.php文件中引用该文章类型文件即可。

// 商品
add_action( 'init', 'post_type_tao' );
function post_type_tao() {
	$labels = array(
		'name'               => '商品', 'post type general name', 'your-plugin-textdomain',
		'singular_name'      => '商品', 'post type singular name', 'your-plugin-textdomain',
		'menu_name'          => '商品', 'admin menu', 'your-plugin-textdomain',
		'name_admin_bar'     => '商品', 'add new on admin bar', 'your-plugin-textdomain',
		'add_new'            => '发布商品', 'tao', 'your-plugin-textdomain',
		'add_new_item'       => '发布新商品', 'your-plugin-textdomain',
		'new_item'           => '新商品', 'your-plugin-textdomain',
		'edit_item'          => '编辑商品', 'your-plugin-textdomain',
		'view_item'          => '查看商品', 'your-plugin-textdomain',
		'all_items'          => '所有商品', 'your-plugin-textdomain',
		'search_items'       => '搜索商品', 'your-plugin-textdomain',
		'parent_item_colon'  => 'Parent 商品:', 'your-plugin-textdomain',
		'not_found'          => '你还没有发布商品。', 'your-plugin-textdomain',
		'not_found_in_trash' => '回收站中没有商品。', 'your-plugin-textdomain'
	);

	$args = array(
		'labels'             => $labels,
		'public'             => true,
		'publicly_queryable' => true,
		'show_ui'            => true,
		'show_in_menu'       => true,
		'query_var'          => true,
		'rewrite'            => array( 'slug' => tao ),
		'capability_type'    => 'post',
		'menu_icon'          => 'dashicons-cart',
		'has_archive'        => false,
		'hierarchical'       => false,
		'menu_position'      => 10,
		'supports'           => array( 'title', 'editor', 'author', 'excerpt', 'comments', 'thumbnail', 'revisions', 'custom-fields' )
	);

	register_post_type( 'tao', $args );
}


// 商品分类
add_action( 'init', 'create_tao_taxonomies', 0 );
function create_tao_taxonomies() {
	$labels = array(
		'name'              => '商品分类目录', 'taxonomy general name',
		'singular_name'     => '商品分类', 'taxonomy singular name',
		'search_items'      => '搜索商品目录',
		'all_items'         => '所有商品目录',
		'parent_item'       => 'Parent Genre',
		'parent_item_colon' => 'Parent Genre:',
		'edit_item'         => '编辑商品目录',
		'update_item'       => '更新商品目录',
		'add_new_item'      => '添加新商品目录',
		'new_item_name'     => 'New Genre Name',
		'menu_name'         => '商品分类',
	);

	$args = array(
		'hierarchical'      => true,
		'labels'            => $labels,
		'show_ui'           => true,
		'show_admin_column' => true,
		'query_var'         => true,
		'rewrite'           => array( 'slug' => taobao),
	);

	register_taxonomy( 'taobao', array( 'tao' ), $args );
}

// 商品标签
add_action( 'init', 'create_tao_tag_taxonomies', 0 );
function create_tao_tag_taxonomies() {
	$labels = array(
		'name'              => '商品标签', 'taxonomy general name',
		'singular_name'     => '商品标签', 'taxonomy singular name',
		'search_items'      => '搜索商品标签',
		'all_items'         => '所有商品标签',
		'parent_item'       => 'Parent Genre',
		'parent_item_colon' => 'Parent Genre:',
		'edit_item'         => '编辑商品标签',
		'update_item'       => '更新商品标签',
		'add_new_item'      => '添加新商品标签',
		'new_item_name'     => 'New Genre Name',
		'menu_name'         => '商品标签',
	);

	$args = array(
		'hierarchical'      => false,
		'labels'            => $labels,
		'show_ui'           => true,
		'show_admin_column' => true,
		'query_var'         => true,
		'rewrite'           => array( 'slug' => taotag ),
	);

	register_taxonomy( 'taotag', array( 'tao' ), $args );
}

 

以上代码为添加自定义类型的文章、分类和标签,具体请自行修改里面自定义类型的标题、slug等内容。想创建多个自定义类型文章、分类和标签,直接重复上述代码,并修改为其他的标题及slug即可。