个人中心项目--朋友圈模块(二)

本文解决个人中心项目中朋友圈模块的点赞功能问题,通过引入两个Map集合优化点赞与取消点赞的状态管理,实现动态用户名的添加与移除,确保按钮状态一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.描述

这部分主要是解决个人中心项目–朋友圈模块(一)中遗留的问题,即:
在这里插入图片描述
修改的代码主要是前端的逻辑,在js部分新加了两个map集合,用于判断每条动态的点赞或是取消点赞的状态,主要思路是给每个按钮都维护一个状态变量timeNumun,而不是(一)中一组按钮维护一个timeNumun而出现状态混乱问题:
在这里插入图片描述

2.具体代码:
2.1 动态添加或取消点赞用户名:

<div class="collapse" th:id="collapseExample+${dynamics.dynamic.id}">
    <div class="card card-body">
        <div  th:each="likes:${dynamics.likes}"  >
            <div th:id="${likes.user.id}+likes+${dynamics.dynamic.id}" th:if="${likes.user} != null" style="word-wrap: break-word;font-family: 华文行楷;font-size: medium;float: left" th:text="${likes.user.username}" > </div>
        </div>
        <div th:id="${dynamics.dynamic.id}+likes" style="word-wrap: break-word;font-family: 华文行楷;font-size: medium;float: left"> </div>
    </div>

</div>

2.2 onclick函数:

 var timeNumun = 0;
    var likeMap = new Map();
    var unlikeMap = new Map();
    function unlike(id,toId,obj,size) {
        if (unlikeMap.has(toId)){

            timeNumun = unlikeMap.get(toId);
        }else {
            timeNumun = 0;
        }
        timeNumun = timeNumun + 1;
        unlikeMap.set(toId,timeNumun);

        var num = size;
        if (timeNumun % 2 == 0) {
            timeNumun = timeNumun + 1;
            var likesToken = id + 'likes' + toId;

            $.ajax({
                type: "GET",
                url: '/dynamic/like?id=' + id + '&toId=' + toId,//url
                success: function (data) {
                    var showText = document.getElementById(obj.id);
                    showText.innerHTML = num  + ' Love';
                    $('#' + obj.id).attr("class", "btn waves-effect btn-sm ml-1 waves-light btn-rounded btn-danger");
                    document.getElementById(likesToken).innerHTML = data;
                },
                error: function () {
                    alert("异常!");
                }

            });
            return false;
        } else if (timeNumun % 2 == 1) {
            timeNumun = timeNumun + 1;
            var likesToken = id + 'likes' + toId;
            $.ajax({
                type: "GET",
                url: '/dynamic/unlike?id=' + id + '&toId=' + toId,//url
                success: function (data) {
                    var showText = document.getElementById(obj.id);
                    showText.innerHTML = num - 1 + ' Love';
                    $('#' + obj.id).attr("class", "btn btn-outline-danger btn-sm ml-1 btn-rounded");
                    document.getElementById(likesToken).innerHTML = '';

                },
                error: function () {
                    alert("异常!");
                }

            });
            return false;
        }
    }
    var timeNum = 0;
    function like(id,toId,obj,size) {
        if (likeMap.has(toId)){

            timeNum = likeMap.get(toId);
        }else {
            timeNum = 0;
        }
        timeNum = timeNum + 1;
        likeMap.set(toId,timeNum);
        var num = size+1;
        var likesToken = toId+'likes';
        if (timeNum % 2 == 1){
            $.ajax({
                type:"GET",
                url:'/dynamic/like?id='+id+'&toId='+toId,//url
                success: function (data) {
                    var showText = document.getElementById(obj.id);
                    showText.innerHTML = num + ' Love';
                    $('#'+obj.id).attr("class","btn waves-effect btn-sm ml-1 waves-light btn-rounded btn-danger");
                    document.getElementById(likesToken).innerHTML = data;
                },
                error : function() {
                    alert("异常!");
                }

            });
            return false;
        }else if (timeNum % 2 == 0){

            $.ajax({
                type:"GET",
                url:'/dynamic/unlike?id='+id+'&toId='+toId,//url
                success: function (data) {
                    var showText = document.getElementById(obj.id);
                    showText.innerHTML = num - 1 + ' Love';
                    $('#'+obj.id).attr("class","btn btn-outline-danger btn-sm ml-1 btn-rounded");
                    document.getElementById(likesToken).innerHTML = '';

                },
                error : function() {
                    alert("异常!");
                }

            });
            return false;
        }
    }


继“Java开发微信朋友圈PC版系统-架构1.0”之后,debug这段时间日撸夜撸,终于赶在春节放假前给诸位带来了这一系统的架构2.0版本,特此分享给诸位进行学习,以掌握、巩固更多的技术栈以及项目和产品开发经验,同时也为即将到来的金三银四跳槽季做准备! 言归正传,下面仍然以问答的方式介绍下本门课程的相关内容! (1)问题一:这是一门什么样的课程? 很明显,本门课程是建立在架构1.0,即 第1门课程 的基础上发布的,包含了架构1.0的内容,即它仍然是一门项目、产品实战课,基于Spring Boot2.X + 分布式中间件开发的一款类似“新浪微博”、“QQ空间”、“微信朋友圈”PC版的互联网社交软件,包含完整的门户网前端 以及 后台系统管理端,可以说是一套相当完整的系统! (2)问题:架构2.0融入了哪些新技术以及各自有什么作用? 本课程对应着系统架构2.0,即第2阶段,主要目标:基于架构1.0,优化系统的整体性能,实现一个真正的互联网社交产品;其中,可以学习到的技术干货非常多,包括:系统架构设计、Spring Boot2.X、缓存Redis、多线程并发编程、消息中间件RabbitMQ、全文搜索引擎Elastic Search、前后端消息实时通知WebSocket、分布式任务调度中间件Elastic Job、Http Restful编程、Http通信OKHttp3、分布式全局唯一ID、雪花算法SnowFlake、注册中心ZooKeeper、Shiro+Redis 集群Session共享、敏感词自动过滤、Java8 等等; A.  基于Elastic Search实现首页列表数据的初始化加载、首页全文检索;B.  基于缓存Redis缓存首页朋友圈“是否已点赞、收藏、关注、评论、转发”等统计数据;整合Shiro实现集群部署模式下Session共享;C.  多线程并发编程并发处理系统产生的废弃图片、文件数据;D.  基于Elastic Job切片作业调度分布式多线程清理系统产生的废弃图片;E.  基于RabbitMQ解耦同步调用的服务模块,实现服务模块之间异步通信;F.  基于WebSocket实现系统后端 与 首页前端 当前登录用户实时消息通知;G.  基于OKHttp3、Restful风格的Rest API实现ES文档、分词数据存储与检索;H.  分布式全局唯一ID 雪花算法SnowFlake实现朋友圈图片的唯一命名;I.  ZooKeeper充当Elastic Job创建的系统作业的注册中心;J.  为塑造一个健康的网络环境,对用户发的朋友圈、评论、回复内容进行敏感词过滤;K.  大量优雅的Java8  Lambda编程、Stream编程;  (3)问题三:系统运行起来有效果图看吗?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值