我用Vue.js实现微信朋友圈的一些功能,实现展示朋友圈,评论,点赞。
先构造一个vue的实例,对会更改的数据进行双向绑定,
我用JSON伪造模版数据,先实现显示朋友圈的效果,使用v-for方法去循环ALLFeeds中的每一项item生成包括name、content、time在内的各项数据。
微信朋友圈实现效果
HTML代码:
<div class="border" v-for="item in AllFeeds" track-by="$index"> <div class="user-pic"> <img v-bind:src="item.url" alt=""> </div> <div class="user-content"> <h2 class="spacing">{{item.name}}</h2> <p class="spacing">{{item.content}}</p> <img class="spacing" v-bind:src="item.picUrl" alt=""> <span class="spacing time">{{item.time}}</span> <div class="commit" v-show="item.showComt"> <a v-on:click="likeClick($event,item)" class="btn btn-left" href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" > <span class="icon-heart-empty"></span>{{item.like}} </a> <a v-on:click="comtClick($event,item)" href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="btn btn-comment"> <span class="icon-comment-alt"></span>评论 </a> </div>
实现朋友圈点赞
当like的值变为赞时,向userLike中push一个点赞的username,然后将like的值变为取消。当用户点击取消按钮的时候,将userLike数组中添加的赞pop掉。
likeClick: function (event, feed) { event.stopPropagation(); if (feed.like === "赞") { if (gUserInfo) { feed.userLike.push(gUserInfo.username); feed.like = '取消'; } } else { if (gUserInfo) { feed.userLike.pop(); feed.like = '赞'; } } }
实现评论功能
input的val()push到content的值里。
inputClick: function (event) { event.stopPropagation(); var comText = $(".inset input").val(); this.clickFeed.comment.push({"name": gUserInfo.username, "content": comText}); $(".inset").addClass("hidden"); $(".overplay").addClass("hidden"); $('.inset input').val(''); }
实现评论回复功能
给comment中添加reply的key。由于微信的回复是平铺的所以只要显示谁对谁的回复即可,不需要进行评论的嵌套。所以HTML中使用v-if对comment中是否存在reply进行判断。
replyClick:function(event){ event.stopPropagation(); var replyText = $(".replybox input").val(); this.clickFeed.comment.push({ "name":gUserInfo.username, "content":replyText, "reply":this.replyUser }); $(".replybox").addClass("hidden"); $(".overplay").addClass("hidden"); $(".replybox input").val(''); }
对comment中是否存在reply进行判断
<div v-if="!(onecommet.reply)"> <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" v-on:click="replyComt($event,item,onecommet)" class="reply"> <span class="user">{{onecommet.name}}:</span> {{onecommet.content}} </a> </div> <div v-else> <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" v-on:click="replyComt($event,item,onecommet)" class="reply"> <span class="user">{{userinfo.username}}</span>回复 <span class="user">{{replyUser}}: <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="reply">{{onecommet.content}}</a> </span> </a> </div>
遇到的坑:
当异步加载JSON的时候,不能直接获取到JSON的值,因为可能等下面函数加载完后JSON的值还未拿到。所以会出现data数据为undefined的情况。所以需要在JSON的回调函数中进行函数调用。
初始化showComt时,需要用到ready,当DOM加载完后再执行。
收获:
学会了使用v-for、v-if、v-show,v-on:click等vue的方法,vue的构造器,jQuery的Ajax相关的方法。
Github链接
项目下载地址:Webchat-friendfeed_jb51.rar
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Javascript 实现微信分享(QQ、朋友圈、分享给朋友),包括了Javascript 实现微信分享(QQ、朋友圈、分享给朋友)的使用技巧和注意事项,需要的朋友参考一下 最近做微信开发,对微信公众号的开发,现在好的都是分享到朋友圈,QQ,分享给好友等分享功能,这里记录下,有需要的朋友也可以看下。 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
本文向大家介绍我也有微信朋友圈了 Android实现,包括了我也有微信朋友圈了 Android实现的使用技巧和注意事项,需要的朋友参考一下 本文实例分享了一个简单的朋友圈程序,包含了朋友圈的列表实现,视频的录制、预览与上传,图片可选择拍照,供大家参考,具体内容如下 FriendsListActivity 代码如下 布局文件 friends_list.xml 适配器 InteractionAdap
本文向大家介绍Android实现微信朋友圈发本地视频功能,包括了Android实现微信朋友圈发本地视频功能的使用技巧和注意事项,需要的朋友参考一下 一、前言 前一篇文章已经详细介绍了如何使用Xposed框架编写第一个微信插件:摇骰子和猜拳作弊器 本文继续来介绍如何使用Xposed框架编写第二个微信插件,可以将本地小视频发布到朋友圈的功能。在这之前我们还是要有老套路,准备工作要做好,这里还是使用微信
本文向大家介绍iOS实现微信朋友圈与摇一摇功能,包括了iOS实现微信朋友圈与摇一摇功能的使用技巧和注意事项,需要的朋友参考一下 本Demo为练手小项目,主要是熟悉目前主流APP的架构模式.此项目中采用MVC设计模式,纯代码和少许XIB方式实现.主要实现了朋友圈功能和摇一摇功能. 预览效果: 主要重点 1.整体架构 利用UITabBarController和UINavigationControlle
本文向大家介绍Android仿微信朋友圈图片查看器,包括了Android仿微信朋友圈图片查看器的使用技巧和注意事项,需要的朋友参考一下 再看文章之前,希望大家先打开自己的微信点到朋友圈中去,仔细观察是不是发现朋友圈里的有个“九宫格”的图片区域,点击图片又会跳到图片的详细查看页面,并且支持图片的滑动和缩放?这个功能是不是很常用呢?!那么我今天正好做了这个Demo,下面为大家讲解一下。首先按照惯例先看
本文向大家介绍Android GridView仿微信朋友圈显示图片,包括了Android GridView仿微信朋友圈显示图片的使用技巧和注意事项,需要的朋友参考一下 最近项目要求上传多图并且多图显示,而且要规则的显示,就像微信朋友圈的图片显示一样。 利用GridView再适合不过了,GridView可以动态加载图片的数量,而且还比较规律,下面说一下自己的思路: 1.获取网络图片 2.初始化gri