vue组件之间通信实例总结(点赞功能)


Posted in Javascript onDecember 05, 2018

本文实例讲述了vue组件之间通信。分享给大家供大家参考,具体如下:

总结:

父组件--》子组件

①通过属性

步骤1:

<son myName="michael" myPhone='123'></son>
<son :myName="userList[0]"></son>

步骤2:

Vue.component('son',{
props:['myName','myPhone']
})

②通过$parent

直接在子组件中通过this.$parent得到调用子组件的父组件

子组件--》父组件

①events up

步骤1:在父组件中 调用子组件的时候 绑定一个自定义事件 和 对应的处理函数

methods:{
recvMsg:function(msg){

//msg就是传递来的数据

}
},
template:'
<son @customEvent="recvMsg"></son>
'

步骤2:在子组件中 把要发送的数据通过触发自定义事件传递给父组件

this.$emit('customEvent',123)

②$refs

reference 引用

步骤1:在调用子组件的时候 可以指定ref属性

<son ref='zhangsan'></son>

步骤2:通过$refs得到指定引用名称对应的组件实例

this.$refs.zhangsan

兄弟组件通信

步骤1:创建一个Vue的实例 作为事件绑定触发的公共的对象

var bus = new Vue();

步骤2:在接收方的组件 绑定 自定义的事件

bus.$on('customEvent',function(msg){
//msg是通过事件传递来的数据 (传递来的123)
});

步骤3:在发送方的组件 触发 自定义的事件

bus.$emit('customEvent',123);

每日一练:

创建2个组件,main-component,son-component

视图:

main-component 显示一个按钮
son-component 显示一个p标签

功能:

main-component 定义一个变量count,初始化为0,将count传递给son-component,son-component接收到数据显示在p标签中

main-component 在点击按钮时,实现对count的自增操作,要求son-component能够实时显示count对应的数据

son-component在接收到count之后,在count大于10的时候,将main-component的按钮禁用掉
(参考:<button v-bind:disabled="!isValid">clickMe</button>)

<!doctype html>
<html>
 <head>
 <meta charset="UTF-8">
 <title>3water.com 小练习</title>
  <script src="https://cdn.bootcss.com/vue/2.0.1/vue.min.js"></script>
 </head>
 <body>
 <div id="container">
    <p>{{msg}}</p>
    <main-component></main-component>
  </div>
  <script>
  /*
    每日一练:
创建2个组件,main-component,son-component
视图:
 main-component 显示一个按钮
 son-component 显示一个p标签
功能:
  main-component 定义一个变量count,初始化为0,将count传递给son-component,son-component接收到数据显示在p标签中
  main-component 在点击按钮时,实现对count的自增操作,要求son-component能够实时显示count对应的数据
  son-component在接收到count之后,在count大于10的时候,将main-component的按钮禁用掉
  (参考:<button v-bind:disabled="!isValid">clickMe</button>)
  */
//创建父组件
    Vue.component("main-component",{
      data:function(){
        return {
          count:0,
          isDisabled:true
        }
      },
      methods:{
        //点击按钮对count进行自增
        //并通过$emit触发countAdd,并把count的值传递给子组件
        //判断count==10的时候让按钮禁用
        countAdd:function(){
          this.count++;
          console.log("对数据进行自增:"+this.count);
          this.$emit("countAdd",this.count);
        }
      },
      template:`
        <div>
          <button @click="countAdd" v-bind:disabled="!isDisabled">点我</button>
          <son-component v-bind:myCount="count"></son-component>
        </div>
      `
    })
//创建子组件
    Vue.component("son-component",{
      //通过props接收父组件传递过来的值
      props:["myCount"],
      template:`
        <div>
          <p>{{myCount}}</p>
        </div>
      `,
      //数据更新完成后判断从父组件拿到的值
      updated:function(){
        if(this.myCount>10){
          //子组件通过$parent直接获取父组件的数据
            this.$parent.isDisabled = false;
          }
      }
    })
    new Vue({
      el:"#container",
      data:{
        msg:"Hello VueJs"
      }
    })
  </script>
 </body>
</html>

使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试,可得到如下运行效果:

vue组件之间通信实例总结(点赞功能)

感兴趣的朋友还可以使用上述在线工具测试一下代码的运行效果。

希望本文所述对大家vue.js程序设计有所帮助。

Javascript 相关文章推荐
ASP小贴士/ASP Tips javascript tips可以当桌面
Dec 10 Javascript
js png图片(有含有透明)在IE6中为什么不透明了
Feb 07 Javascript
javascript获取当前鼠标坐标的方法
Jan 10 Javascript
JS+CSS实现Li列表隔行换色效果的方法
Feb 16 Javascript
jQuery实现冻结表格行和列
Apr 29 Javascript
jQuery实现下拉加载功能实例代码
Apr 01 Javascript
jQuery简单实现上下,左右滑动的方法
Jun 01 Javascript
谈谈JavaScript的New关键字
Aug 26 Javascript
JavaScript 对象详细整理总结
Sep 29 Javascript
详解webpack4多入口、多页面项目构建案例
May 25 Javascript
angularjs $http调用接口的方式详解
Aug 13 Javascript
jQuery实现获取当前鼠标位置并输出功能示例
Jan 05 jQuery
JS获取今天是本月第几周、本月共几周、本月有多少天、是今年的第几周、是今年的第几天的示例代码
Dec 05 #Javascript
JS获取月的第几周和年的第几周实例代码
Dec 05 #Javascript
JavaScript实现学生在线做题计时器功能
Dec 05 #Javascript
vue-cli3搭建项目的详细步骤
Dec 05 #Javascript
详解vue中async-await的使用误区
Dec 05 #Javascript
Vue中的基础过渡动画及实现原理解析
Dec 04 #Javascript
使用FormData实现上传多个文件
Dec 04 #Javascript
You might like
单位速度在实战中的运用
2020/03/04 星际争霸
《星际争霸II》全新指挥官斯台特曼现已上线
2020/03/08 星际争霸
PHP 文件上传进度条的两种实现方法的代码
2007/11/25 PHP
7个鲜为人知却非常实用的PHP函数
2015/07/01 PHP
php实现上传图片文件代码
2015/07/19 PHP
laravel创建类似ThinPHP中functions.php的全局函数
2016/11/26 PHP
PHP插件PHPMailer发送邮件功能
2017/02/28 PHP
php基于Redis消息队列实现的消息推送的方法
2018/11/28 PHP
在Laravel中使用GuzzleHttp调用第三方服务的API接口代码
2019/10/15 PHP
可以显示单图片,多图片ajax请求的ThickBox3.1类下载
2007/12/23 Javascript
商城常用滚动的焦点图效果代码简单实用
2013/03/28 Javascript
计算新浪Weibo消息长度(还可以输入119字)
2013/07/02 Javascript
关于jquery的多个选择器的使用示例
2013/10/18 Javascript
详解JavaScript 中的 replace 方法
2016/01/01 Javascript
jQuery UI Bootstrap是什么?
2016/06/17 Javascript
Webpack+Vue如何导入Jquery和Jquery的第三方插件
2017/02/20 Javascript
jQuery插件echarts实现的去掉X轴、Y轴和网格线效果示例【附demo源码下载】
2017/03/04 Javascript
javascript 中关于array的常用方法详解
2017/05/05 Javascript
Vue仿支付宝支付功能
2018/05/25 Javascript
微信小程序时间戳转日期的详解
2019/04/30 Javascript
JS使用for in有序获取对象数据
2020/05/19 Javascript
javascript实现前端分页效果
2020/06/24 Javascript
vue实现下拉菜单树
2020/10/22 Javascript
Python os.access()用法实例
2019/02/18 Python
Python3离线安装Requests模块问题
2019/10/13 Python
tensorflow 实现打印pb模型的所有节点
2020/01/23 Python
Python PyQt5运行程序把输出信息展示到GUI图形界面上
2020/04/27 Python
党员干部公开承诺书
2014/03/26 职场文书
房屋公证委托书
2014/04/03 职场文书
会计专业自荐书
2014/07/08 职场文书
企业党建工作汇报材料
2014/08/19 职场文书
中学生运动会新闻稿
2014/09/24 职场文书
2014年流动人口工作总结
2014/11/26 职场文书
2016年小学生新年寄语
2015/08/18 职场文书
2015年社区反邪教工作总结
2015/10/14 职场文书
python playwright 自动等待和断言详解
2021/11/27 Python