VueJs组件之父子通讯的方式 组件(父子通讯) 一、概括 在一个组件内定义另一个组件,称之为父子组件。 但是要注意的是:1.子组件只能在父组件内部使用(写在父组件tempalte中); 2.默认情况下,子组件无法访问父组件上的数据,每个组件实例的作用域是独立的; 那如何完成父子如何完成通讯,简单一句话:props down, events up :父组件通过 props 向下传递数据给子组件,子组件通过 events 给父组件发送 父传子:Props 子传父:子:$emit(eventName) 父$on(eventName) 父访问子:ref 下面对三个进行案例讲解: 二、父传子:Props  组件实例的作用域是孤立的。这意味着不能 (也不应该) 在子组件的模板内直接引用父组件的数据。要让子组件使用父组件的数据,需要通过子组件的 props 选项   使用Prop传递数据包括静态和动态两种形式,下面先介绍静态props 1、静态props
效果: 命名约定: 对于props声明的属性来说,在父级HTML模板中,属性名需要使用中划线写法 子级props属性声明时,使用小驼峰或者中划线写法都可以;而子级模板使用从父级传来的变量时,需要使用对应的小驼峰写法 上面这句话什么意思呢? 如果我们childNode中的myMessage改成{{my-message}}看运行结果: 2.动态props 在模板中,要动态地绑定父组件的数据到子模板的 props,与绑定到任何普通的HTML特性相类似,就是用 v-bind。每当父组件的数据变化时,该变化也会传导给子组件 var childNode = { template: '
{{myMessage}}
', props: ['my-message'] } var parentNode = { template: `
`, components: { 'child': childNode }, data() { return { 'data1': '111', 'data2': '222' } } }; 3、传递数字 初学者常犯的一个错误是使用字面量语法传递数值
结果: 因为它是一个字面 prop,它的值是字符串 "1" 而不是 number。如果想传递一个实际的 number,需要使用 v-bind,从而让它的值被当作JS表达式计算 如何把String转成number呢,其实只要改一个地方。 var parentNode = { template: `
//只要把父组件my-message="1"改成:my-message="1"结果就变成number类型
`, }; 当然你如果想通过v-bind想传一个string类型,那该怎么做呢? 我们可以使用动态props,在data属性中设置对应的数字1 var parentNode = { template: `
`, components: { 'myChild': childNode }, //这里'data': 1代表就是number类型,'data': "1"那就代表String类型 data(){ return { 'data': 1 } } }; 三、子转父 :$emit 关于$emit的用法 1、父组件可以使用 props 把数据传给子组件。 2、子组件可以使用 $emit 触发父组件的自定义事件。 子主键 父组件