Maison > interface Web > js tutoriel > le corps du texte

VueJs组件之父子通讯的方式

不言
Libérer: 2018-05-07 14:57:36
original
1192 人浏览过

这篇文章主要介绍了VueJs组件之父子通讯的方式,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

组件(父子通讯)

一、概括

在一个组件内定义另一个组件,称之为父子组件。

   但是要注意的是:1.子组件只能在父组件内部使用(写在父组件tempalte中);

                                2.默认情况下,子组件无法访问父组件上的数据,每个组件实例的作用域是独立的;

那如何完成父子如何完成通讯,简单一句话:props down, events up :父组件通过 props 向下传递数据给子组件,子组件通过 events 给父组件发送

父传子:Props
子传父:子:$emit(eventName) 父$on(eventName)
父访问子:ref

下面对三个进行案例讲解:

二、父传子:Props

     组件实例的作用域是孤立的。这意味着不能 (也不应该) 在子组件的模板内直接引用父组件的数据。要让子组件使用父组件的数据,需要通过子组件的 props 选项

  使用Prop传递数据包括静态和动态两种形式,下面先介绍静态props

1、静态props


Copier après la connexion

效果:

命名约定:

对于props声明的属性来说,在父级HTML模板中,属性名需要使用中划线写法

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

上面这句话什么意思呢?

Copier après la connexion

如果我们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' } } };
Copier après la connexion

3、传递数字

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


Copier après la connexion

结果:

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

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

 var parentNode = {
  template: `
 

//只要把父组件my-message="1"改成:my-message="1"结果就变成number类型

`, };
Copier après la connexion

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

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

var parentNode = {
 template: `
 

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

三、子转父 :$emit

关于$emit的用法

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

子主键

 
Copier après la connexion

父组件