WordPress实现评论后可显示内容的方法

简介

内容来源于网络搜集

先看下使用样式,结构比较简单,我一般都是套用其他的样式一起使用,这样才会突出显示

[reply]123[/reply]

由于WP主题不支持在文章中的显示内容不可见,而且,也没有找到类似的插件,所以在网上找了一些代码,勉强使用以下 [collapse title=”点击查看”]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
function reply_to_read($atts, $content=null) {
extract(shortcode_atts(array("notice" => '温馨提示: 此处内容需要评论本文后才能查看.'), $atts));
$email = null;
$user_ID = (int) wp_get_current_user()->ID;
if ($user_ID > 0) {
$email = get_userdata($user_ID)->user_email;
//对博主直接显示内容
$admin_email = "xxx@aaa.com"; //博主Email
if ($email == $admin_email) {
return $content;
}
} else if (isset($_COOKIE['comment_author_email_' . COOKIEHASH])) {
$email = str_replace('%40', '@', $_COOKIE['comment_author_email_' . COOKIEHASH]);
} else {
return $notice;
}
if (empty($email)) {
return $notice;
}
global $wpdb;
$post_id = get_the_ID();
$query = "SELECT `comment_ID` FROM {$wpdb->comments} WHERE `comment_post_ID`={$post_id} and `comment_approved`='1' and `comment_author_email`='{$email}' LIMIT 1";
if ($wpdb->get_results($query)) {
return do_shortcode($content);
} else {
return $notice;
}
}
add_shortcode('reply', 'reply_to_read');

[/collapse] 不过使用时需要注意的是:

要修改第8行的邮件为管理员的。如果你的网站使用了ajax免刷新提交评论,应该还需要修改第2行的提示文字,提示访客评论后刷新页面来查看隐藏内容。

使用方法

将以上代码复制到主题编辑文件functions.php中使用,使用前记得先备份源文件

另外在编辑文件时,直接插入以下代码即可 [collapse title=”点击查看”]

1
2
【reply】评论可见的内容【/reply】或 
【reply notice="自定义的提示信息"】评论可见的内容【/reply】

[/collapse]

注意其中的符号是英文下的[]