!
也想出现在这里? 联系我们
广告位

WordPress纯代码实现用户关注功能

用户关注功能可能最早出现在的是微博上,登录用户可以关注别人,自己也可以被关注,那们使用 WordPress 开发带用户注册的主题的时候是否也可以实现关注功能的,答案是肯定的,今天就给大家分享一下使用纯代码实现 WordPress 用户关注功能的实现方法。首先,将下面的代码放到您的 functions.php 文件中。

  1. function wpdiary_user_guanzhu(){
  2. if(!get_current_user_id()){
  3. exit(json_encode(['msg'=>'请登录!']));
  4. }
  5. if( $_POST['user']==get_current_user_id()){
  6. exit(json_encode(['msg'=>'你不能关注自己!']));
  7. }
  8. $user = $_POST['user'];
  9. $meta = get_user_meta(get_current_user_id(),'guanzhu',true);
  10. $bguanzhu1 = explode(',',get_user_meta($user,'bguanzhu',true));
  11. $bguanzhu = array_filter($bguanzhu1);
  12. $guanzhu1 = explode(',',get_user_meta(get_current_user_id(),'guanzhu',true));
  13. $guanzhu = array_filter($guanzhu1);
  14. if(in_array($user,$guanzhu)){
  15. foreach($guanzhu as $k=>$v){
  16. if($v==$user){
  17. unset($guanzhu[$k]);
  18. }
  19. }
  20. foreach($bguanzhu as $k=>$v){
  21. if($v==get_current_user_id()){
  22. unset($bguanzhu[$k]);
  23. }
  24. }
  25. update_user_meta(get_current_user_id(),'guanzhu',implode(",",$guanzhu));
  26. update_user_meta($user,'bguanzhu',implode(",",$bguanzhu));
  27. exit(json_encode(['msg'=>'取消成功!']));
  28. }else{
  29. array_push($guanzhu,$user);
  30. array_push($bguanzhu,get_current_user_id());
  31. update_user_meta(get_current_user_id(),'guanzhu',implode(",",$guanzhu));
  32. update_user_meta($user,'bguanzhu',implode(",",$bguanzhu));
  33. exit(json_encode(['msg'=>'关注成功!']));
  34. }
  35. }
  36. add_action('wp_ajax_guanzhu','wpdiary_user_guanzhu');
  37. add_action('wp_ajax_nopriv_guanzhu','wpdiary_user_guanzhu');
  38. //获取指定用户关注数量
  39. function get_wpdiary_guanzhu_count($authorID){
  40. $meta = get_user_meta($authorID,'guanzhu',true);
  41. if($meta){
  42. $guanzhu = explode(",",get_user_meta($authorID,'guanzhu',true));
  43. return count($guanzhu);
  44. }else{
  45. return 0;
  46. }
  47. }
  48. //获取指定用户被关注数量
  49. function get_wpdiary_bguanzhu_count($authorID){
  50. $meta = get_user_meta($authorID,'bguanzhu',true);
  51. if($meta){
  52. $bguanzhu = explode(",",get_user_meta($authorID,'bguanzhu',true));
  53. return count($bguanzhu);
  54. }else{
  55. return 0;
  56. }
  57. }

其次,消息提示使用了 layer 这个 jQuery 弹出层插件,所以,您还需要在主题中引入这个框架的文件(下载地址:http://res.layui.com/static/download/layer/layer-v3.1.1.zip),下载后把整个文件夹放到您的主题目录中,然后在主题头部引入 layer.js,并将下面的 JS 代码放到您的 footer.php 中。

  1. <script>
  2. $('a.addfollow').click(function(){
  3. var user = $(this).attr('user');
  4. $.ajax({
  5. url: "/wp-admin/admin-ajax.php",
  6. type:'post',
  7. dataType:'json',
  8. data:{action:'guanzhu',user:user},
  9. success: function(data){
  10. layer.alert(data.msg, function(){
  11. location.reload();
  12. });
  13. }
  14. });
  15. });
  16. </script>

第三,将关注按钮放到您需要放的地方,比如用户列表中或作者存档页,关注按钮代码如下:

  1. <?php
  2. $meta = get_user_meta(get_current_user_id(),'guanzhu',true);
  3. $user = ‘要被关注的用户的ID’
  4. if($meta){
  5. $guanzhu = explode(',',$meta);
  6. }else{
  7. $guanzhu = array();
  8. }
  9. if(in_array($user,$guanzhu)){?>
  10. <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" user="<?php echo $user;?>" class="addfollow focus-link">+取消关注</a>
  11. <?php }else{?>
  12. <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" user="<?php echo $user;?>" class="addfollow focus-link">+ 关注</a>
  13. <?php }?>

第四,获取指定用户关注和被关注数量:

  1. <?php echo get_wpdiary_guanzhu_count(‘用户ID’);?>//获取指定用户关注数量
  2. <?php echo get_wpdiary_bguanzhu_count(‘用户ID’);?>//获取指定用户被关注数量

第五,如何获取当前登录用户关注的用户的列表:

  1. <?php
  2. $user_id = get_current_user_id();//当前登录用户id,也可以指定为某个ID的用户,这样获取到的就是指定ID的用户的关注列表
  3. $meta = get_user_meta($user_id,'guanzhu',true);
  4. $guanzhulist = explode(',',$meta );
  5. $users = get_users(array('include'=>$guanzhulist));
  6. ?>
  7. <?php foreach($users as $user){ ?>
  8. <li class="pic-btn-li">
  9. <div class="li-pic">
  10. <a href="<?php%20echo%20get_author_posts_url(%20$user->ID);%20?>/?userid=<?php%20echo%20$user->ID;?>" target="_blank" class="li-link">
  11. <?php echo get_avatar($user->ID);?>
  12. </a>
  13. </div>
  14. <div class="li-dec">
  15. <p class="dec-name">
  16. <a href="<?php%20echo%20get_author_posts_url(%20$user->ID);%20?>/?userid=<?php%20echo%20$user->ID;?>" target="_blank" class="dec-name-link"><?php echo $user->nickname;?></a>
  17. </p>
  18. <p class="dec-sub">
  19. <span class="dec-fans">粉丝 <?php echo get_wpdiary_bguanzhu_count($user->ID);?></span>
  20. </p>
  21. </div>
  22. <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" user="<?php echo $user->ID;?>" class="addfollow sp-mod-button" title="关注他">取消</a>
  23. </li>
  24. <?php } ?>

第六,获取关注过当前登录用户的列表(被关注列表,也可以说是粉丝列表):

  1. <?php
  2. $user_id = get_current_user_id();//当前登录用户id,也可以指定为某个ID的用户,这样获取到的就是关注过指定ID的用户列表(粉丝列表)
  3. $bguanzhu = get_user_meta($user_id,'bguanzhu',true);
  4. $fanslist = explode(',',$bguanzhu );
  5. $fans = get_users(array('include'=>$fanslist));
  6. ?>
  7. <?php foreach($fans as $fensi){ ?>
  8. <li class="pic-btn-li">
  9. <div class="li-pic">
  10. <a href="<?php%20echo%20get_author_posts_url(%20$fensi->ID);%20?>/?userid=<?php%20echo%20$fensi->ID;?>" target="_blank" class="li-link">
  11. <?php echo get_avatar($fensi->ID);?>
  12. </a>
  13. </div>
  14. <div class="li-dec">
  15. <p class="dec-name">
  16. <a href="<?php%20echo%20get_author_posts_url(%20$fensi->ID);%20?>/?userid=<?php%20echo%20$fensi->ID;?>" target="_blank" class="dec-name-link"><?php echo $fensi->nickname;?></a>
  17. </p>
  18. <p class="dec-sub">
  19. <span class="dec-fans">粉丝 <?php echo get_wpdiary_bguanzhu_count($fensi->ID);?></span>
  20. </p>
  21. </div>
  22. <?php
  23. $meta = get_user_meta(get_current_user_id(),'guanzhu',true);
  24. $user = $fensi->ID;
  25. if($meta){
  26. $guanzhu = explode(',',get_user_meta(get_current_user_id(),'guanzhu',true));
  27. }else{
  28. $guanzhu = array();
  29. }
  30. if(in_array($user,$guanzhu)){?>
  31. <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" user="<?php echo $fensi->ID;?>" class="addfollow sp-mod-button" title="取消关注">已互关</a>
  32. <?php }else{?>
  33. <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" user="<?php echo $fensi->ID;?>" class="addfollow sp-mod-button" title="关注他">关注他</a>
  34. <?php }?>
  35. </li>
  36. <?php } ?>

好了,就这些了,用心的朋友仔细看一看代码还会让你的关注功能更加的丰富,希望对大家有用!

WordPress 纯代码实现用户关注功能

已有 312 人购买
    此资源下载价格为2元立即购买(VIP 免费)立即升级
查看演示升级 VIP立刻购买

给TA打赏
共{{data.count}}人
人已打赏
WordPress教程

纯代码实现WordPress中提醒安装插件功能

2023-12-1 13:59:19

WordPress教程

WordPress 添加历史上的今天文章列表

2023-12-8 13:52:22

下载说明

  • 1、微码盒所提供的压缩包若无特别说明,解压密码均为weimahe.com
  • 2、下载后文件若为压缩包格式,请安装7Z软件或者其它压缩软件进行解压;
  • 3、文件比较大的时候,建议使用下载工具进行下载,浏览器下载有时候会自动中断,导致下载错误;
  • 4、资源可能会由于内容问题被和谐,导致下载链接不可用,遇到此问题,请到文章页面进行反馈,以便微码盒及时进行更新;
  • 5、其他下载问题请自行搜索教程,这里不一一讲解。

站长声明

本站大部分下载资源收集于网络,只做学习和交流使用,版权归原作者所有;若为付费资源,请在下载后24小时之内自觉删除;若作商业用途,请到原网站购买;由于未及时购买和付费发生的侵权行为,与本站无关。本站发布的内容若侵犯到您的权益,请联系本站删除,我们将及时处理!
0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索