在 vue.js 中,父组件包含子组件,通过 props 和 slots 进行通信。注册父组件,在模板中插入子组件占位符 (slot),并传递 props。父组件可传递数据给子组件,子组件可触发事件,父组件监听并处理。

Vue 父组件:使用指南
在 Vue.js 中,父组件是包含一个或多个子组件的组件。子组件通过 props 与父组件进行通信,而父组件则通过 slots 来控制子组件的呈现方式。
如何使用父组件
在 Vue template 中使用父组件,遵循以下步骤:
立即学习“前端免费学习笔记(深入)”;
- 注册父组件:在 Vue 实例的 components 选项中,注册父组件。
- 创建父组件模板:父组件模板负责定义子组件的容器和占位符。
- 使用插槽:在父组件模板中,使用插槽 () 将子组件内容插入到父组件中。
- 传递 props:父组件将 props 传递给子组件,以配置子组件的行为。
示例
mallcloud商城基于SpringBoot2.x、SpringCloud和SpringCloudAlibaba并采用前后端分离vue的企业级微服务敏捷开发系统架构。并引入组件化的思想实现高内聚低耦合,项目代码简洁注释丰富上手容易,适合学习和企业中使用。真正实现了基于RBAC、jwt和oauth2的无状态统一权限认证的解决方案,面向互联网设计同时适合B端和C端用户,支持CI/CD多环境部署,并提
<code class="vue">// ParentComponent.vue
<template>
<div>
<slot></slot> <!-- 占位符,接收子组件内容 -->
</div>
</template></code><code class="vue">// ChildComponent.vue <template> <h1>我是子组件</h1> </template></code>
<code class="vue">// App.vue
<template>
<ParentComponent>
<ChildComponent></ChildComponent> <!-- 插入子组件 -->
</ParentComponent>
</template></code>传递 props
父组件可以通过 props 向子组件传递数据。在父组件中,使用 v-bind 绑定 props 到子组件:
<code class="vue">// ParentComponent.vue <template> <ChildComponent :message="message"></ChildComponent> </template></code>
在子组件中,声明 props 并使用 :propName 语法访问父组件传递的值:
<code class="vue">// ChildComponent.vue
<script>
export default {
props: ['message']
}
</script>
<template>
<h1>{{ message }}</h1>
</template></code>事件处理
子组件可以向父组件触发事件。在子组件中,使用 $emit 方法触发事件:
<code class="vue">// ChildComponent.vue
<script>
export default {
methods: {
clickHandler() {
this.$emit('child-click') // 触发 child-click 事件
}
}
}
</script>
<template>
<button @click="clickHandler">点击我</button>
</template></code>在父组件中,使用 v-on 监听子组件触发的事件:
<code class="vue">// ParentComponent.vue <template> <ChildComponent @child-click="handleChildClick"></ChildComponent> </template></code>









