全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

我用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

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


# Vue微信朋友圈  # vue.js  # 微信开发  # vuejs  # 微信分享  # Vue组件大全包括(UI组件  # 开发框架  # 服务端  # 辅助工具  # 应用实例  # Demo示例)  # vue动态改变背景图片demo分享  # vue.js配合$.post从后台获取数据简单demo分享  # Vue.js实现的表格增加删除demo示例  # 用 Vue.js 递归组件实现可折叠的树形菜单(demo)  # 用Go+Vue.js快速搭建一个Web应用(初级demo)  # 基于vue的短信验证码倒计时demo  # Vue仿手机qq的实例代码(demo)  # Vue插件写、用详解(附demo)  # 详解Vue demo实现商品列表的展示  # 我用  # 加载  # 完后  # 是否存在  # 平铺  # 下载地址  # 不需要  # 还未  # 谁的  # 绑定  # 回调  # 大家多多  # 每一项  # 组中  # 学会了  # src  # bind  # url  # alt  # gt 


相关文章: 如何通过PHP快速构建高效问答网站功能?  完全自定义免费建站平台:主题模板在线生成一站式服务  建站之星安装需要哪些步骤及注意事项?  如何选择适配移动端的WAP自助建站平台?  网站制作多少钱一个,建一个论坛网站大约需要多少钱?  导航网站建站方案与优化指南:一站式高效搭建技巧解析  代购小票制作网站有哪些,购物小票的简要说明?  建站三合一如何选?哪家性价比更高?  Thinkphp 中 distinct 的用法解析  如何快速登录WAP自助建站平台?  宝塔建站后网页无法访问如何解决?  相册网站制作软件,图片上的网址怎么复制?  建站之星如何快速生成多端适配网站?  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略  如何快速搭建高效简练网站?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  如何快速查询网站的真实建站时间?  大连网站制作公司哪家好一点,大连买房网站哪个好?  免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?  清除minerd进程的简单方法  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  5种Android数据存储方式汇总  大学网站设计制作软件有哪些,如何将网站制作成自己app?  香港服务器租用费用高吗?如何避免常见误区?  广州营销型建站服务商推荐:技术优势与SEO优化解析  如何配置FTP站点权限与安全设置?  网站制作免费,什么网站能看正片电影?  制作网站的公司有哪些,做一个公司网站要多少钱?  再谈Python中的字符串与字符编码(推荐)  常州自助建站工具推荐:低成本搭建与模板选择技巧  如何在IIS管理器中快速创建并配置网站?  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  如何通过VPS建站无需域名直接访问?  C++用Dijkstra(迪杰斯特拉)算法求最短路径  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  建站主机选哪家性价比最高?  如何通过远程VPS快速搭建个人网站?  如何用西部建站助手快速创建专业网站?  如何通过VPS搭建网站快速盈利?  怀化网站制作公司,怀化新生儿上户网上办理流程?  文字头像制作网站推荐软件,醒图能自动配文字吗?  建站之星体验版:智能建站系统+响应式设计,多端适配快速建站  建站10G流量真的够用吗?如何应对访问高峰?  如何通过cPanel快速搭建网站?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  已有域名能否直接搭建网站?  如何在云指建站中生成FTP站点? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。