相思资源网 Design By www.200059.com
将通过两个input框实现父子之间的值传递作为演示,效果图
先注册父子各一个组件,代码如下
<div id="app">
<parent></parent>
</div>
<template id="parent">
<div>
<input type="text" v-model="text" placeholder="parent">
<son></son>
</div>
</template>
<template id="son">
<div>
<input type="text" placeholder="son">
</div>
</template>
new Vue({
el: "#app",
components: {
parent: {
template: '#parent',
data() {
return {
text: ''
}
},
components: {
son: {
template: '#son'
}
}
}
}
})
一、父传子
再父组件通过属性传递值
<template id="parent">
<div>
<input type="text" v-model="text" placeholder="parent">
<son :text="text"></son>//通过属性值传递
</div>
</template>
子组件通过props属性接受
components: {
son: {
template: '#son',
props:['text'] //通过props属性接受父传递过来的值
}
}
这样我们就可以使用父组件传递过来的值了
<template id="son">
<div>
<input type="text" placeholder="son" :value="text">//使用父元素传递过来的值
</div>
</template>
看下现在的效果
父组件向子组件传递成功
二、子传父
通过父组件自定义事件,然后子组件用$emit(event,aguments)调用
<template id="parent">
<div>
<input type="text" v-model="text" placeholder="parent">
<son :text="text" @ev="item"></son>//自定义事件
</div>
</template>
components: {
parent: {
template: '#parent',
data() {
return {
text: ''
}
},
components: {
son: {
template: '#son',
props: ['text']
}
},
methods: {
item(v) { //自定义事件触发的方法
this.text = v //使用子组件传递过来的值改变this.text数据
}
}
}
}
再子组件触发自定义事件
<template id="son">
<div>
<input type="text" placeholder="son" :value="text" @input="emit" ref="son">//触发自定义事件
</div>
</template>
components: {
parent: {
template: '#parent',
data() {
return {
text: ''
}
},
components: {
son: {
template: '#son',
props: ['text'],
methods: {
emit() {
this.$emit('ev', this.$refs.son.value) //触发自定义事件,并传递值
}
}
}
},
methods: {
item(v) {
this.text = v
}
}
}
}
这样就完成了子传父,父传子,效果也完成了
总结
相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com
暂无Vue父子之间值传递的实例教程的评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。


