博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
WordPress添加AJAX文章点赞功能
阅读量:4047 次
发布时间:2019-05-25

本文共 2000 字,大约阅读时间需要 6 分钟。

这里写图片描述

来自Fatesinger,文章赞功能随处可见,例如无觅的相关文章工具、百度分享等等。如果想要给主题专门集成点赞功能,还是得需要下面的代码实现。用自定义字段保存赞数量,通过Cookies来禁止重复赞。

加入至Functions.php文件中:

add_action('wp_ajax_nopriv_bigfa_like', 'bigfa_like');add_action('wp_ajax_bigfa_like', 'bigfa_like');function bigfa_like(){
global $wpdb,$post; $id = $_POST["um_id"]; $action = $_POST["um_action"]; if ( $action == 'ding'){ $bigfa_raters = get_post_meta($id,'bigfa_ding',true); $expire = time() + 99999999; $domain = ($_SERVER['HTTP_HOST'] != 'localhost') ? $_SERVER['HTTP_HOST'] : false; // make cookies work with localhost setcookie('bigfa_ding_'.$id,$id,$expire,'/',$domain,false); if (!$bigfa_raters || !is_numeric($bigfa_raters)) { update_post_meta($id, 'bigfa_ding', 1); } else { update_post_meta($id, 'bigfa_ding', ($bigfa_raters + 1)); } echo get_post_meta($id,'bigfa_ding',true); } die;}

相对应的JS代码:

$(document).ready(function() {
$.fn.postLike = function() {
if ($(this).hasClass('done')) { return false; } else { $(this).addClass('done'); var id = $(this).data("id"), action = $(this).data('action'), rateHolder = $(this).children('.count'); var ajax_data = { action: "bigfa_like", um_id: id, um_action: action }; $.post("/wp-admin/admin-ajax.php", ajax_data, function(data) {
$(rateHolder).html(data); }); return false; }};$(document).on("click", ".favorite",function() {
$(this).postLike();});});

调用代码:

喜欢
ID,'bigfa_ding',true) ){ echo get_post_meta($post->ID,'bigfa_ding',true); } else { echo '0'; }?>

参考CSS样式

.post-like{
text-align:center;padding:10px}.post-like a{ background-color:#21759B;border-radius: 3px;color: #FFFFFF;font-size: 12px;padding: 5px 10px;text-decoration: none;outline:none}.post-like a.done, .post-like a:hover{
background-color:#eee;color:#21759B;} .post-like a.done{
cursor:not-allowed}

点击无效问题解决

  请引用版本为1.10或以上的jQuery。

转载地址:http://hfuci.baihongyu.com/

你可能感兴趣的文章
计算机网络复习要点
查看>>
Variable property attributes or Modifiers in iOS
查看>>
NSNotificationCenter 用法总结
查看>>
C primer plus 基础总结(一)
查看>>
剑指offer算法题分析与整理(三)
查看>>
Ubuntu 13.10使用fcitx输入法
查看>>
pidgin-lwqq 安装
查看>>
mint/ubuntu安装搜狗输入法
查看>>
C++动态申请数组和参数传递问题
查看>>
opencv学习——在MFC中读取和显示图像
查看>>
如何将PaperDownloader下载的文献存放到任意位置
查看>>
C/C++中关于动态生成一维数组和二维数组的学习
查看>>
JVM最简生存指南
查看>>
Java的对象驻留
查看>>
JVM并发机制探讨—内存模型、内存可见性和指令重排序
查看>>
持续可用与CAP理论 – 一个系统开发者的观点
查看>>
nginx+tomcat+memcached (msm)实现 session同步复制
查看>>
c++字符数组和字符指针区别以及str***函数
查看>>
c++类的操作符重载注意事项
查看>>
c++模板与泛型编程
查看>>