粥里有勺糖

vuePress-theme-reco 粥里有勺糖    2018 - 2023
粥里有勺糖 粥里有勺糖

Choose mode

  • dark
  • auto
  • light
关于我
备战春秋
  • 心得总结
  • 校招考点汇总
  • 面经汇总
  • 复习自查
技术笔记
  • 技术教程
  • 模板工程
  • 源码学习
  • 技术概念
  • 个人作品
  • 学习笔记
计算机基础
  • 算法与数据结构
  • 操作系统
  • 计算机网络
  • 设计模式
  • 剑指offer
大前端
  • javascript
  • vue
  • html
  • css
  • 🌏浏览器专题
  • Web性能优化
  • regexp
  • node
面试
  • 问解
  • javascript
  • css
  • 手撕代码
  • 性能优化
  • 综合问题
  • 面经汇总
  • 小程序
手撕代码
  • 数据结构与算法
  • javascript
  • css
个人站点
  • GitHub (opens new window)
  • 博客园 (opens new window)
  • 掘金 (opens new window)
线上作品
  • 轻取(文件收集) (opens new window)
  • 个人图床 (opens new window)
  • 考勤小程序 (opens new window)
  • 时光恋人 (opens new window)
  • 在线简历生成 (opens new window)
留言板
Github (opens new window)
author-avatar

粥里有勺糖

285

文章

40

标签

关于我
备战春秋
  • 心得总结
  • 校招考点汇总
  • 面经汇总
  • 复习自查
技术笔记
  • 技术教程
  • 模板工程
  • 源码学习
  • 技术概念
  • 个人作品
  • 学习笔记
计算机基础
  • 算法与数据结构
  • 操作系统
  • 计算机网络
  • 设计模式
  • 剑指offer
大前端
  • javascript
  • vue
  • html
  • css
  • 🌏浏览器专题
  • Web性能优化
  • regexp
  • node
面试
  • 问解
  • javascript
  • css
  • 手撕代码
  • 性能优化
  • 综合问题
  • 面经汇总
  • 小程序
手撕代码
  • 数据结构与算法
  • javascript
  • css
个人站点
  • GitHub (opens new window)
  • 博客园 (opens new window)
  • 掘金 (opens new window)
线上作品
  • 轻取(文件收集) (opens new window)
  • 个人图床 (opens new window)
  • 考勤小程序 (opens new window)
  • 时光恋人 (opens new window)
  • 在线简历生成 (opens new window)
留言板
Github (opens new window)
  • Vue

    • 简介
    • 响应式基本原理
    • 路由原理
    • 生命周期钩子
    • 组件通信
    • extend API
    • mixin与mixins
    • computed与watch
    • keep-alive
    • v-show 与 v-if
    • ❤运行机制概述
    • ❤响应式系统的依赖收集追踪原理
    • ❤VNode实现
    • 编译template的过程
    • 数据状态更新时的差异 diff 及 patch 机制

组件通信

vuePress-theme-reco 粥里有勺糖    2018 - 2023

组件通信

粥里有勺糖 2020-04-14 大前端vue

# 组件通信

# 父子通信

# props与emit

父组件通过 props 传递数据给子组件,子组件通过 emit 发送事件传递数据给父组件,这种父子通信方式也就是典型的单向数据流,父组件通过 props 传递数据,子组件不能直接修改 props, 而是必须通过发送事件的方式告知父组件修改数据。

<!--父组件中-->
<input :param1="val" @changeparam1="callback"/>
<!--子组件中-->
<script>
  this.$emit('changeparam1', 1)
</script>
1
2
3
4
5
6

# v-model

v-model 默认会解析成名为 value 的 prop 和名为 input 的事件。这种语法糖的方式是典型的双向绑定,但是究其根本,还是通过事件的方法让父组件修改数据。

子组件

<div>
    <input @input="handleInput" :value="value"/>
</div>
<script>
export default{
    props: {
        value: String
    },
    methods: {
        handleInput(e) {
            this.$emit('input', e.target.value)
        }
    }
}
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

父组件

<h1>{{param1}}</h1>
<fw-input v-model="param1"></fw-input>
<script>
export default{
    date(){
        return {
            param:'666'
        }
    }
}
</script>
1
2
3
4
5
6
7
8
9
10
11

# $parent与$children

通过访问 $parent 或者 $children 对象来访问组件实例中的方法和数据

子组件

<div><button @click="changeParent" type="button">{{value}}</button></div>
<script>
export default{
    data(){
        return{
            value:'child'
        }
    },
    methods: {
        changeParent(e) {
            this.$parent.$data.param1='change by child'
        }
    }
}
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

父组件

<h1>{{param1}}</h1>
<fw-child></fw-child>
<button @click="changeChild" type="button">parent</button>

<script>
export default{
    data(){
        return{
            param1: '123'
        }
    },
    methods: {
        changeChild(){
            this.$children[0].$data.value='change by parent'
        }
    }
}
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

# $listeners

$listeners 属性会将父组件中的 (不含 .native 修饰器的) v-on 事件监听器传递给子组件,子组件可以通过访问 $listeners 来自定义监听器。

子组件

<div><input v-on="inputListeners" :value="value"/></div>
<script>
export default{
    props: {
        value: String
    },
    computed: {
        inputListeners() {
            let that = this;
            return Object.assign({}, that.$listeners, {
                input(e) {
                    that.$emit('input', e.target.value)
                }
            })
        }
    }
}
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

父组件

<h1>{{param1}}</h1>
<fw-input2 v-model="param1"></fw-input2>
<script>
export default{
    data(){
        return{
            param1: '123'
        }
    }
}
</script>
1
2
3
4
5
6
7
8
9
10
11

# .sync

.sync 属性是个语法糖,可以很简单的实现子组件与父组件通信 子组件

<div><input @input="handleInput" :value="value"/></div>
<script>
export default{
    props: {
        value: String
    },
    methods: {
        handleInput(e) {
            this.$emit('update:value', e.target.value)
        }
    }
}
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13

父组件

<h1>{{param1}}</h1>
<fw-input3 :value.sync="param1"></fw-input3>
<script>
export default{
    data(){
        return{
            param1: '123'
        }
    }
}
</script>
1
2
3
4
5
6
7
8
9
10
11

# 兄弟组件通信

通过查找父组件中的子组件实现,this.$parent.$children,在 $children 中可以通过组件 name 查询到需要的组件实例,然后进行通信。

# 跨多层次组件通信

# provide / inject

子组件

<div>{{parentValue}}</div>
<script>
export default{
    inject:['parentValue']
}
</script>
1
2
3
4
5
6

父组件

<deep-child></deep-child>
<script>
export default{
    provide:{
        parentValue:666
    }
}
</script>
1
2
3
4
5
6
7
8

# 任意组件

使用 Vuex 或者 Event Bus

# 示例

CodePen:示例 (opens new window)

Edit this page (opens new window)
Last Updated: 2022/5/15 12:46:34