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针对DOM的应用实例(一)
Apr 15 Javascript
jQuery经过一段时间自动隐藏指定元素的方法
Mar 17 Javascript
Jquery简单分页实现方法
Jul 24 Javascript
jQuery简单操作cookie的插件实例
Jan 13 Javascript
JS使用cookie设置样式的方法
Jun 30 Javascript
详解jQuery事件
Jan 13 Javascript
React Native中导航组件react-navigation跨tab路由处理详解
Oct 31 Javascript
解决vue-router在同一个路由下切换,取不到变化的路由参数问题
Sep 01 Javascript
微信小程序实现的五星评价功能示例
Apr 25 Javascript
JS数组及对象遍历方法代码汇总
Jun 16 Javascript
Js数组扁平化实现方法代码总汇
Nov 11 Javascript
一篇文章让你搞懂JavaScript 原型和原型链
Nov 23 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
php获取后台Job管理的实现代码
2011/06/10 PHP
php加水印的代码(支持半透明透明打水印,支持png透明背景)
2013/01/17 PHP
基于php设计模式中单例模式的应用分析
2013/05/15 PHP
php 解压rar文件及zip文件的方法
2014/05/05 PHP
php实现的农历算法实例
2015/08/11 PHP
PHP表单提交后引号前自动加反斜杠的原因及三种办法关闭php魔术引号
2015/09/30 PHP
值得分享的php+ajax实时聊天室
2016/07/20 PHP
PHP利用百度ai实现文本和图片审核
2019/05/08 PHP
关于图片验证码设计的思考
2007/01/29 Javascript
JS字符串函数扩展代码
2011/09/13 Javascript
javascript内置对象arguments详解
2014/03/16 Javascript
jquery序列化表单以及回调函数的使用示例
2014/07/02 Javascript
Node.js中的process.nextTick使用实例
2015/06/25 Javascript
学习JavaScript设计模式之策略模式
2016/01/12 Javascript
JQuery异步加载PartialView的方法
2016/06/07 Javascript
Vue-cli-webpack搭建斗鱼直播步骤详解
2017/11/17 Javascript
代码详解Vuejs响应式原理
2017/12/20 Javascript
zTree树形菜单交互选项卡效果的实现方法
2017/12/25 Javascript
nodejs实现OAuth2.0授权服务认证
2017/12/27 NodeJs
浅谈js闭包理解
2019/04/01 Javascript
微信小程序+云开发实现欢迎登录注册
2019/05/24 Javascript
vuex 中插件的编写案例解析
2019/06/10 Javascript
es6中Promise 对象基本功能与用法实例分析
2020/02/23 Javascript
小程序实现密码输入框
2020/11/16 Javascript
python使用xmlrpc实例讲解
2013/12/17 Python
Python实现的一个找零钱的小程序代码分享
2014/08/25 Python
spyder常用快捷键(分享)
2017/07/19 Python
详解python里使用正则表达式的全匹配功能
2017/10/19 Python
Python原始套接字编程实例解析
2020/01/29 Python
python数字类型math库原理解析
2020/03/02 Python
python为什么要安装到c盘
2020/07/20 Python
美国室内和室外装饰花盆购物网站:ePlanters
2019/03/22 全球购物
大学生个人事迹材料
2014/01/21 职场文书
宗教学大学生职业生涯规划范文
2014/02/08 职场文书
运动会班级口号
2014/06/09 职场文书
导游词之河姆渡遗址博物馆
2019/10/10 职场文书