微信小程序制犯案例_Vue.js完成模仿微信朋友圈开

摘要: Vue.js完成仿真模拟手机微信微信朋友圈开发设计demo 我用JSON仿冒模板数据信息,先完成显示信息微信朋友圈的实际效果,应用v-for方式去循环系统ALLFeeds中的每一项item转化成包含...

Vue.js实现模拟微信朋友圈开发demo       本篇文章主要介绍了Vue.js实现模拟微信朋友圈开发demo,实现展示朋友圈,评论,点赞等功能,有兴趣的可以了解一下。

我用JSON伪造模版数据,先实现显示朋友圈的效果,使用v-for方法去循环ALLFeeds中的每一项item生成包括name、content、time在内的各项数据。

微信朋友圈实现效果

HTML代码:

 div v-for="item in AllFeeds" track-by="$index" 
 div 
 img v-bind:src="item.url" alt="" 
 /div 
 div 
 h2 {{item.name}} /h2 
 p {{item.content}} /p 
 img v-bind:src="item.picUrl" alt="" 
 span {{item.time}} /span 
 div v-show="item.showComt" 
 a v-on:click="likeClick($event,item)" href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" 
 span /span {{item.like}}
 a v-on:click="comtClick($event,item)" href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" 
 span /span 评论
 /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();
 Text = $(".inset input").val();
 ment.push({"name": gUserInfo.username, "content": comText});
 $(".inset").addClass("hidden");
 $(".overplay").addClass("hidden");
 $('.inset input').val('');
 }

实现评论回复功能

给comment中添加reply的key。由于微信的回复是平铺的所以只要显示谁对谁的回复即可,不需要进行评论的嵌套。ment中是否存在reply进行判断。

 replyClick:function(event){
 event.stopPropagation();
 var replyText = $(".replybox input").val();
 ment.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,met)" 
 span {{onecommet.name}}: /span 
 {{onecommet.content}}
 /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,met)" 
 span {{.username}} /span 回复 span {{replyUser}}:
 a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" {{onecommet.content}} /a 
 /span 
 /div 

遇到的坑:

当异步加载JSON的时候,不能直接获取到JSON的值,因为可能等下面函数加载完后JSON的值还未拿到。所以会出现data数据为undefined的情况。所以需要在JSON的回调函数中进行函数调用。

初始化showComt时,需要用到ready,当DOM加载完后再执行。

收获:

学会了使用v-for、v-if、v-show,v-on:click等vue的方法,vue的构造器,jQuery的Ajax相关的方法。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持凡科。




联系我们

全国服务热线:4000-399-000 公司邮箱:343111187@qq.com

  工作日 9:00-18:00

关注我们

官网公众号

官网公众号

Copyright?2020 广州凡科互联网科技股份有限公司 版权所有 粤ICP备10235580号 客服热线 18720358503

技术支持:自助建站