Python语言技术文档

微信小程序技术文档

php语言技术文档

jsp语言技术文档

asp语言技术文档

C#/.NET语言技术文档

html5/css技术文档

javascript

点击排行

您现在的位置:首页 > 技术文档 > js框架/js库

VueJs组件之父子通讯的方式

来源:中文源码网    浏览:189 次    日期:2024-04-15 16:59:17
【下载文档:  VueJs组件之父子通讯的方式.txt 】


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 触发父组件的自定义事件。
子主键


父组件