Vue 中 $attrs 与 $listeners 的详解
介绍
$attrs
继承所有的父组件属性(没有通过 props 接收的属性还有 class 类名 和 style 样式 )。
inheritAttrs:
是否非 props 属性显示在标签最外层,默认值 true ,就是继承所有的父组件属性(除了 props 特定绑定外)作为普通的 HTML 特性应用在子组件的根元素上,如果你不希望组件的根元素继承特性就设置 inheritAttrs: false ,但是 class 还是会继承。
$listeners
它是一个对象,能接收所有的方法绑定,里面包含了作用在这个组件上的所有监听器,配合 v-on="$listeners" 将所有的事件监听器指向这个组件的某个特定的子元素。前端培训
举例
父组件中
复制代码
子组件中
复制代码
可见,当 inheritAttrs 默认 false 时,属性是传入到子组件最外层的
![](https://static001.geekbang.org/infoq/0d/0de1d9581e2771a165b3708a28b9d53c.png)
当 inheritAttrs 为 true 后
![](https://static001.geekbang.org/infoq/6c/6c4096fb04bccc77a164e45ffc4647ce.png)
当使用 props 接收属性时,属性就不会被显示
![](https://static001.geekbang.org/infoq/7b/7bd1685c2df0379ea946403d0cce8707.png)
总结:组件标签上传入的属性如果子组件没有接收会跑到子组件标签最外层。
非 props 属性可以通过 $attrs 接收 {属性名:属性值}
复制代码
当给子组件绑定点击事件时,是不会触发点击事件的,可以使用 .native 修饰符进行绑定成功
![](https://static001.geekbang.org/infoq/d6/d67cea3eb8ad87b8090e2b0eb0b5839e.png)
或者通过 $listeners 进行接收所有方法的绑定
子组件内
![](https://static001.geekbang.org/infoq/0b/0b3798b465414e827e2560fe4a263c5e.png)
结果
![](https://static001.geekbang.org/infoq/51/51aea0fddc79ab51af2ff7d12f8ea7d5.png)
总结 :
所有非 props 属性都可以通过 $attrs 接收
使用:v-bind="$attrs" 将所有非 props 属性绑定到相应标签,也可以用于组件
所有组件上的方法绑定子组件都可以通过 $listeners 接收
使用:v-on="$listeners"将所有方法又绑定到组件相应标签,也可以用于组件