Vue.js实现模拟微信朋友圈开发demo


Posted in Javascript onApril 20, 2017

我用Vue.js实现微信朋友圈的一些功能,实现展示朋友圈,评论,点赞。

先构造一个vue的实例,对会更改的数据进行双向绑定,

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

微信朋友圈实现效果

Vue.js实现模拟微信朋友圈开发demo

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相关的方法。

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

Javascript 相关文章推荐
javascript脚本编程解决考试分数统计问题
Oct 18 Javascript
JavaScript实现多维数组的方法
Nov 20 Javascript
js完整倒计时代码分享
Sep 18 Javascript
bootstrap栅格系统示例代码分享
May 22 Javascript
jquery.validate.js 多个相同name的处理方式
Jul 10 jQuery
react配置antd按需加载的使用
Feb 11 Javascript
详解element-ui中form验证杂记
Mar 04 Javascript
详解小程序用户登录状态检查与更新实例
May 15 Javascript
Weex开发之WEEX-EROS开发踩坑(小结)
Oct 16 Javascript
vue-cli在 history模式下的配置详解
Nov 26 Javascript
vue中选中多个选项并且改变选中的样式的实例代码
Sep 16 Javascript
vue中实现弹出层动画效果的示例代码
Sep 25 Javascript
AngularJS 单选框及多选框的双向动态绑定
Apr 20 #Javascript
Vue如何引入远程JS文件
Apr 20 #Javascript
AngularJS改变元素显示状态
Apr 20 #Javascript
bootstrap 设置checkbox部分选中效果
Apr 20 #Javascript
详解Vue2.0之去掉组件click事件的native修饰
Apr 20 #Javascript
AngularJS实现根据不同条件显示不同控件
Apr 20 #Javascript
详解Vuejs2.0之异步跨域请求
Apr 20 #Javascript
You might like
9条PHP编程小知识及易犯的小错误
2015/01/22 PHP
php mysql获取表字段名称和字段信息的三种方法
2016/11/13 PHP
js 对联广告、漂浮广告封装类(IE,FF,Opera,Safari,Chrome
2009/11/26 Javascript
JQuery Tips(4) 一些关于提高JQuery性能的Tips
2009/12/19 Javascript
写js时遇到的一些小问题
2010/12/06 Javascript
node.js中使用socket.io制作命名空间
2014/12/15 Javascript
javascript中call和apply的用法示例分析
2015/04/02 Javascript
讲解JavaScript中for...in语句的使用方法
2015/06/03 Javascript
KnockoutJs快速入门教程
2016/05/16 Javascript
图文详解JavaScript的原型对象及原型链
2016/08/02 Javascript
js利用clipboardData实现截屏粘贴功能
2016/10/12 Javascript
关于Vue.js 2.0的Vuex 2.0 你需要更新的知识库
2016/11/30 Javascript
基于jQuery Easyui实现登陆框界面
2017/07/10 jQuery
JS实现图片旋转动画效果封装与使用示例
2018/07/09 Javascript
vue3.0 CLI - 2.5 - 了解组件的三维
2018/09/14 Javascript
vue使用localStorage保存登录信息 适用于移动端、PC端
2019/05/27 Javascript
[50:15]VP vs Mineski 2018国际邀请赛淘汰赛BO3 第二场 8.22
2018/08/23 DOTA
在Python中编写数据库模块的教程
2015/04/29 Python
Python基于Matplotlib库简单绘制折线图的方法示例
2017/08/14 Python
python字符串常用方法
2018/06/14 Python
75条笑死人的知乎神回复,用60行代码就爬完了
2019/05/06 Python
Python数据处理篇之Sympy系列(五)---解方程
2019/10/12 Python
python实现将一维列表转换为多维列表(numpy+reshape)
2019/11/29 Python
浅谈Python爬虫原理与数据抓取
2020/07/21 Python
基于Pytorch版yolov5的滑块验证码破解思路详解
2021/02/25 Python
Puccini乌克兰:购买行李箱、女士手袋网上商店
2020/08/06 全球购物
什么是View State?
2013/01/27 面试题
Java如何获得ResultSet的总行数
2016/09/03 面试题
扩大国家免疫规划实施方案
2014/03/21 职场文书
股权投资意向书
2014/04/01 职场文书
竞选卫生委员演讲稿
2014/04/28 职场文书
保洁公司服务承诺书
2014/05/28 职场文书
2014市府办领导班子“四风问题”对照检查材料思想汇报
2014/09/24 职场文书
离婚协议书格式
2014/11/21 职场文书
力克胡哲观后感
2015/06/10 职场文书
2015年暑期实践报告范文
2015/07/13 职场文书