WordPress代码实现最近浏览历史功能
这个方法不需要使用js,而是利用Cookies记录访客曾经浏览过的文章,展示浏览历史功能。方法很简单
步骤一
首先将下面的代码加入functions.php文件中
/* 相关参数: */
$zg_cookie_expire = 360; // cookie过期的时间,默认值是360天
$zg_number_of_posts = 10; // 显示篇数,默认值是10。
$zg_recognize_pages = true; // 页面模板是否也要设置cookies?默认值是true
function zg_lwp_header() {
if (is_single()) {
zg_lw_setcookie();
} else if (is_page()) {
global $zg_recognize_pages;
if ($zg_recognize_pages === true) {
zg_lw_setcookie();
}
}
}
function zg_lw_setcookie() {
global $wp_query;
$zg_post_ID = $wp_query->post->ID;
if (! isset($_COOKIE["WP-LastViewedPosts"])) {
$zg_cookiearray = array($zg_post_ID);
} else {
$zg_cookiearray = unserialize(preg_replace('!s:(d+):"(.*?)";!e', "'s:'.strlen('$2').':"$2";'", stripslashes($_COOKIE["WP-LastViewedPosts"])));
if (! is_array($zg_cookiearray)) {
$zg_cookiearray = array($zg_post_ID);
}
}
if (in_array($zg_post_ID, $zg_cookiearray)) {
$zg_key = array_search($zg_post_ID, $zg_cookiearray);
array_splice($zg_cookiearray, $zg_key, 1);
}
array_unshift($zg_cookiearray, $zg_post_ID);
global $zg_number_of_posts;
while (count($zg_cookiearray) > $zg_number_of_posts) {
array_pop($zg_cookiearray);
}
$zg_blog_url_array = parse_url(get_bloginfo('url'));
$zg_blog_url = $zg_blog_url_array['host'];
$zg_blog_url = str_replace('www.', '', $zg_blog_url);
$zg_blog_url_dot = '.';
$zg_blog_url_dot .= $zg_blog_url;
$zg_path_url = $zg_blog_url_array['path'];
$zg_path_url_slash = '/';
$zg_path_url .= $zg_path_url_slash;
global $zg_cookie_expire;
setcookie("WP-LastViewedPosts", serialize($zg_cookiearray), (time()+($zg_cookie_expire*86400)), $zg_path_url, $zg_blog_url_dot, 0);
}
function zg_recently_viewed() {
echo '<ul class="viewed_posts">';
if (isset($_COOKIE["WP-LastViewedPosts"])) {
$zg_post_IDs = unserialize(preg_replace('!s:(d+):"(.*?)";!e', "'s:'.strlen('$2').':"$2";'", stripslashes($_COOKIE["WP-LastViewedPosts"])));
foreach ($zg_post_IDs as $value) {
global $wpdb;
$zg_get_title = $wpdb->get_results("SELECT post_title FROM $wpdb->posts WHERE ID = '$value+0' LIMIT 1");
foreach($zg_get_title as $zg_title_out) {
echo "<li><a href="". get_permalink($value+0) . "" title="". $zg_title_out->post_title . "">". wp_trim_words($zg_title_out->post_title,15) . "</a></li>n";
}
}
} else {
}
echo '</ul>';
}
add_action('get_header','zg_lwp_header');注意:其中的zg_recently_viewed()即为为输出浏览历史的函数,上面代码最后部分我用wp_trim_words函数对输出的文章标题进行了截断。
步骤二
有了输出函数,我们只要把它添加到自己想要的位置即可,比如侧栏,文章页某个位置,代码如下:
<?php if (function_exists('zg_recently_viewed')): if (isset($_COOKIE["WP-LastViewedPosts"])) { ?>
<h2>Last viewed posts</h2>
<?php zg_recently_viewed(); ?>
<?php } endif; ?>最后是添加样式,根据自己的主题来吧。
特别说明
以上代码源自:last-viewed-posts插件,这个功能有个bug,如果你的主题控制浏览新文章是在新窗口打开的话会出现多余的cookies,也就会出现多余的浏览历史,若是右键新窗口打开则不会,目前还不知道如何解决。
栏 目:WordPress
本文地址:https://121.40.58.76/CMSjiaocheng/25227.html
您可能感兴趣的文章
- 10-23WordPress取消英文标点符号自动替换中文标点符号的优雅方法
- 10-23如何手动将本地WordPress站点迁移到主机/服务器?
- 10-23利用WordPress移动设备判断函数wp_is_mobile()进行差异化的广告投放
- 10-23两行代码禁用 WordPress 5.0 的 Gutenberg(古腾堡) 编辑器
- 10-23WordPress小工具在指定页面显示的插件:AH Display Widgets
- 10-23给WordPress旧文章增加自定义提示内容
- 10-23WordPress回复已有评论自动添加“@原评论者昵称”
- 10-23WordPress删除文章多余的自定义字段及值
- 10-23实现WordPress文章展开/收缩的效果
- 10-23实现WordPress文章输入密码可见隐藏内容


阅读排行
- 1WordPress取消英文标点符号自动替换中文标点符号的优雅方法
- 2如何手动将本地WordPress站点迁移到主机/服务器?
- 3利用WordPress移动设备判断函数wp_is_mobile()进行差异化的广告投放
- 4两行代码禁用 WordPress 5.0 的 Gutenberg(古腾堡) 编辑器
- 5WordPress小工具在指定页面显示的插件:AH Display Widgets
- 6给WordPress旧文章增加自定义提示内容
- 7WordPress回复已有评论自动添加“@原评论者昵称”
- 8WordPress删除文章多余的自定义字段及值
- 9实现WordPress文章展开/收缩的效果
- 10实现WordPress文章输入密码可见隐藏内容
推荐教程
- 09-22wordpress如何添加描述
- 10-19纯代码给WordPress网站添加独立下载页面功能
- 10-18wordpress无插件调用随机文章的方法
- 10-18WordPress 技巧:WordPress 后台也使用七牛云存储
- 10-19WordPress上传图片HTTP错误的解决方法
- 10-18让注册用户可以上传自己的头像的WordPress插件-WP User Avatar v2.
- 10-23Win10蓝牙无法连接设备怎么办?Win10蓝牙无法连接设备的解决方法
- 10-18WordPress禁用自动更新检测的方法
- 10-18#WordPress小技巧#纯代码为自己博客添加支付宝/微信打赏功能
- 10-22WordPress自动拒绝敏感字评论的方法





