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属性声明时,使用小驼峰或者中划线写法都可以;而子级模板使用从父级传来的变量时,需要使用对应的小驼峰写法

上面这句话什么意思呢?

//这里需要注意的是props可以写成['my-message']或者['myMessage']都是可以的 //但是template里的属性名,只能是驼峰式{{myMessage}},如果也写成{{my-message}}那么是无效的 var childNode = { template: '
{{myMessage}}
',props: ['myMessage'] }

//这里的属性名为my-message
var parentNode = {
template: `
<div class="parent">
<child my-message="我是">
<child my-message="徐小小">

`,components: { 'child': childNode } };

如果我们childNode中的myMessage改成{{my-message}}看运行结果:

2.动态props

在模板中,要动态地绑定父组件的数据到子模板的 props,与绑定到任何普通的HTML特性相类似,就是用 v-bind。每当父组件的数据变化时,该变化也会传导给子组件

{{myMessage}}
',props: ['my-message'] }

var parentNode = {
template: `
<div class="parent">
<child :my-message="data1">
<child :my-message="data2">

`,components: { 'child': childNode },data() { return { 'data1': '111','data2': '222' } } };

3、传递数字

初学者常犯的一个错误是使用字面量语法传递数值

结果:

因为它是一个字面 prop,它的值是字符串 "1" 而不是 number。如果想传递一个实际的 number,需要使用 v-bind,从而让它的值被当作JS表达式计算

如何把String转成number呢,其实只要改一个地方。

`,};

当然你如果想通过v-bind想传一个string类型,那该怎么做呢?

我们可以使用动态props,在data属性中设置对应的数字1

`,components: { 'myChild': childNode },//这里'data': 1代表就是number类型,'data': "1"那就代表String类型 data(){ return { 'data': 1 } } };

三、子转父 :$emit

关于$emit的用法

1、父组件可以使用 props 把数据传给子组件。 2、子组件可以使用 $emit 触发父组件的自定义事件。

子主键

大连

父组件

//监听子组件的showCityName事件。