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: ' `,components: {
'child': childNode
}
};
{{myMessage}} ',props: ['myMessage']
}
//这里的属性名为my-message 如果我们childNode中的myMessage改成{{my-message}}看运行结果: 2.动态props 在模板中,要动态地绑定父组件的数据到子模板的 props,与绑定到任何普通的HTML特性相类似,就是用 v-bind。每当父组件的数据变化时,该变化也会传导给子组件 {{myMessage}} ',props: ['my-message']
}
var parentNode = { 3、传递数字 初学者常犯的一个错误是使用字面量语法传递数值 结果: 因为它是一个字面 prop,它的值是字符串 "1" 而不是 number。如果想传递一个实际的 number,需要使用 v-bind,从而让它的值被当作JS表达式计算 如何把String转成number呢,其实只要改一个地方。 当然你如果想通过v-bind想传一个string类型,那该怎么做呢? 我们可以使用动态props,在data属性中设置对应的数字1 三、子转父 :$emit关于$emit的用法 1、父组件可以使用 props 把数据传给子组件。 2、子组件可以使用 $emit 触发父组件的自定义事件。 子主键 大连
父组件 结果为:toCity: 大连 第二个案例 <div id="counter-event-example"> {{ total }} 详细讲解: 1:button-counter作为父主键,父主键里有个button按钮。 2:两个button都绑定了click事件,方法里: this.$emit('increment1','kkk']);,那么就会去调用父类v-on所监听的increment1事件。 3:当increment1事件被监听到,那么执行incrementTotal,这个时候才会把值传到父组件中,并且调用父类的方法。 4:这里要注意第二个button-counter所对应的v-on:'increment2,而它里面的button所对应是this.$emit('increment1','kkk']);所以第二个button按钮是无法把值传给他的父主键的。 示例:一个按钮点击一次那么它自身和上面都会自增1,而第二个按钮只会自己自增,并不影响上面这个。 还有就是第一个按钮每点击一次,后台就会打印一次如下: 四、ref ($refs)用法ref 有三种用法 1.ref 加在普通的元素上,用this.ref.name 获取到的是dom元素 2.ref 加在子组件上,用this.ref.name 获取到的是组件实例,可以使用组件的所有方法。 3.如何利用v-for 和ref 获取一组数组或者dom 节点 1.ref 加在普通的元素上,用this.ref.name 获取到的是dom元素 <div id="ref-outside-component" v-on:click="consoleRef"> ref在外面的组件上 效果:当在div访问内点击一次: 2.ref使用在外面的元素上 <div id="ref-outside-dom" v-on:click="consoleRef">
效果:当在div访问内点击一次: 3.ref使用在里面的元素上---局部注册组件 ref在里面的元素上 效果:当在click范围内点击一次: 4.ref使用在里面的元素上---全局注册组件 效果:当我第一次输入1时,值已改变出发事件,当我第二次在输入时在触发一次事件,所以后台应该打印两次 总结以上所述是小编给大家介绍的VueJs组件之父子通讯的方式,希望对大家有所帮助,如果大家有任何疑问欢迎各我留言,小编会及时回复大家的! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |