vue中父子组件传递信息实现
2024-10-21 09:20:48
为了能够在父子组件中实现双向控制,需要以下的步骤:
第一步:子组件中挖坑
(1)在需要父组件填充具体内容的地方挖坑,方式为
<slot name="message"></slot>
通过slot和name指定坑
第二步:父组件中填坑(具体内容)
(1)引入子组件作为其中一个模块
在父组件的script中通过import引入,然后通过components进行挂载,最后以标签的形式使用
(2)在子组件模块区域内,使用slot="name的值"指定需要填的坑
<p slot="message">//填坑的内容 <span>加入购物车成功</span>
</p>
上述两步只是实现了组件简单内容的填充,但涉及到值的传递,及控制时还需如下的操作
(1)父组件中的值传递到子组件中:
子组件使用props拿到传递过来的值(在子组件的export default中)
此时父组件与值组件的代码为:
父组件:
<Modal v-bind:mdShow="mdShow" >//Modal是子组件在父组件中
<p slot="message">
请先登录,否则无法加入购物车!
</p>
</Modal> <script>
import Modal from '@/components/Modal.vue'
export default {
data () {
return {
mdShow: false,
}
},
components: {
Modal
},
}
</script>
子组件中代码为:
<div v-bind:class="{'md-show':mdShow}"> <div class="confirm-tips">
<slot name="message"></slot>
</div> </div>
<script>
export default{
props: ["mdShow"],//接受到来自父组件的值
data(){
return { }
},
}
}
</script>
(2)子组件控制父组件中的值:实质上通过子组件的方法间接 通过$emit方法去调用父组件中的方法,
例如父组件有一个方法为close
<p v-on:close="closeModal">
<Modal v-bind:mdShow="mdShow" >//Modal是子组件在父组件中
<p slot="message">
请先登录,否则无法加入购物车!
</p>
</Modal>
</p>
<script>
import Modal from '@/components/Modal.vue'
export default {
data () {
return {
mdShow: false,
}
},
components: {
Modal
},
methods:{
closeModel(){
this.mdShow = true;
}
}
</script>
(2)子组件中需要触发父中绑定的close方法
<div v-bind:class="{'md-show':mdShow}"> <div @clicki="closeModal">Close<div>
<div class="confirm-tips"> <slot name="message"></slot> </div> </div> <script>
export default{
props: ["mdShow"],
data(){
return { }
},
methods: {
closeModal(){
this.$emit("close");//触发父组件中定义的方法
}
}
}
</script>
初学阶段简单总结一下:子组件中挖坑,父组件填坑。
前面两步骤只是简单实现组件的加载,对于有值传递和控制,需要通过该后面两步的props接受来自父组件的值 和$emit触发父组件的方法实现。
最新文章
- 面向对象课后深入学习(C++ 类的静态成员详细讲解)
- linux 使用fdisk分区扩容
- LCD内核自带驱动分析
- AllanCodeMaker 代码生成器 release0.9.0 下载 支持C#,Java,可自订模板
- tiff或tif文件的读取
- 全国行政区划代码(json对象版)
- lintcode 中等题:Majority number II 主元素 II
- HDU 5874 Friends and Enemies
- SRM 599 DIV 2
- nginx变量
- How to change pager CSS in CGridView CListView in Yii
- C#。5 函数 类
- 第35讲 Activity入门和跳转
- Historical节点
- Java IO流--练习
- layui样式修改记录
- 201621123031 《Java程序设计》第2周学习总结
- [Codeforces]860E Arkady and a Nobody-men
- itest 开源测试管理项目中封装的下拉列表小组件:实现下拉列表使用者前后端0行代码
- 1.openshift
热门文章
- 树的dfs序 &;&; 系统栈 &;&; c++ rope
- Grid_自绘
- Tensorflow中使用CNN实现Mnist手写体识别
- XSS 跨站脚本攻击实例1
- 【VS2013编译DirectX Tutorials时遇到的错误】";const wchar_t *"; 类型的实参与 ";LPCSTR"; 类型的形参不兼容
- Git学习--版本回退
- jdbc connection为什么放在webINF的lib里面
- L119
- python数据类型、操作符
- POJ1733:Parity game