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 相关文章推荐
javascript 短路法代码精简
Aug 20 Javascript
jQuery 动画弹出窗体支持多种展现方式
Apr 29 Javascript
实现点击列表弹出列表索引的两种方式
Mar 08 Javascript
js禁止回车提交表单的示例代码
Dec 23 Javascript
JavaScript加入收藏夹功能(兼容IE、firefox、chrome)
May 05 Javascript
JS+CSS实现的简单折叠展开多级菜单效果
Sep 12 Javascript
jQuery实现菜单栏导航效果
Aug 15 jQuery
canvas+gif.js打造自己的数字雨头像的示例代码
Oct 26 Javascript
区别JavaScript函数声明与变量声明
Sep 12 Javascript
vue: WebStorm设置快速编译运行的方法
Oct 18 Javascript
Vue获取页面元素的相对位置的方法示例
Feb 05 Javascript
vue-cli+webpack项目打包到服务器后,ttf字体找不到的解决操作
Aug 28 Javascript
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
索尼SONY ICF-SW7600GR电路分析与改良
2021/03/02 无线电
深入解析fsockopen与pfsockopen的区别
2013/07/05 PHP
PHP写的简单数字验证码实例
2017/05/23 PHP
Laravel模型间关系设置分表的方法示例
2018/04/21 PHP
判断浏览器的javascript版本的代码
2010/09/03 Javascript
简洁Ajax函数处理(示例代码)
2013/11/15 Javascript
javascript学习笔记之函数定义
2015/06/25 Javascript
AngularJS删除路由中的#符号的方法
2016/09/20 Javascript
全面解析node 表单的图片上传
2016/11/21 Javascript
Jquery+Ajax+xml实现中国地区选择三级联动菜单效果(推荐)
2017/06/09 jQuery
layui中table表头样式修改方法
2018/08/15 Javascript
Vue 实现分页与输入框关键字筛选功能
2020/01/02 Javascript
python聊天程序实例代码分享
2013/11/18 Python
Python-基础-入门 简介
2014/08/09 Python
Python双精度浮点数运算并分行显示操作示例
2017/07/21 Python
Python实现的双色球生成功能示例
2017/12/18 Python
pandas DataFrame 根据多列的值做判断,生成新的列值实例
2018/05/18 Python
Python实现繁?转为简体的方法示例
2018/12/18 Python
简单了解python的一些位运算技巧
2019/07/13 Python
详解python实现数据归一化处理的方式:(0,1)标准化
2019/07/17 Python
python3中rank函数的用法
2019/11/27 Python
tensorflow2.0与tensorflow1.0的性能区别介绍
2020/02/07 Python
Python转换字典成为对象,可以用&quot;.&quot;方式访问对象属性实例
2020/05/11 Python
虚拟机下载python是否需要联网
2020/07/27 Python
Ariat官网:美国马靴和服装品牌
2019/12/16 全球购物
工厂厂长岗位职责
2013/11/08 职场文书
中学门卫岗位职责
2013/12/26 职场文书
教学大赛获奖感言
2014/01/15 职场文书
上课打牌的检讨书
2014/02/15 职场文书
化学教学随笔感言
2014/02/19 职场文书
安全生产承诺书范文
2014/05/22 职场文书
第二批党的群众路线教育实践活动总结报告
2014/10/30 职场文书
开除员工通知
2015/04/22 职场文书
导游词之苏州寒山寺
2019/12/05 职场文书
Python Matplotlib库实现画局部图
2021/11/17 Python
Pandas数据结构之Series的使用
2022/03/31 Python