IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue中$attrs和$listeners 的使用 -> 正文阅读

[JavaScript知识库]vue中$attrs和$listeners 的使用

1、attrs属性就包含了所有父组件传来的数据(除开已经props声明了的)

当父组件传递了很多数据给子组件时,子组件没有声明props来进行接收,那么子组件中的attrs属性就包含了所有父组件传来的数据(除开已经props声明了的),子组件还可以使用v?bind="attrs属性就包含了所有父组件传来的数据(除开已经props声明了的),子组件还可以使用v-bind="attrs属性就包含了所有父组件传来的数据(除开已经props声明了的),子组件还可以使用v?bind="attrs"的形式向它的子组件(孙子组件)传递数据,孙子组件使用$attrs的方式和它的父组件原理类似。

// 父组件
<template>
  <div>
    <p>父级组件</p>
    <div>
      <button @click="changeMsg">更改数据</button>     
    </div>
    <div>子组件数据:{{ fromchildData }}</div>
    <child1 ref="child1" :msg="msg" v-model="fromchildData" :msg1="msg1" :msg2="msg2" :msg3="msg3" :msg4="msg4" @childData="childData"></child1>
  </div>
</template>
<script>
import child1 from './child1.vue';
export default {
  data() {
    return {
      msg: '父组件默认值',
      msg1: 'parent数据1',
      msg2: 'parent数据2',
      msg3: 'parent数据3',
      msg4: 'parent数据4',
      fromchildData: ''
    };
  },
  components: {
    child1
  },
  methods: {
    // 点击按钮更改数据
    changeMsg() {
      this.msg = '父组件主动改变值';
    },
    // 子组件的回调方法
    childData(data) {
      this.fromchildData = data;
    },

  }
};
</script>
// 子组件 child1.vue
<template>
  <div class="child-1">
    <p>--child1组件--</p>
    <div>
      <button @click="sendData">传递数据给父组件</button>
      <button @click="getParentData">使用$parent</button>
      <button @click="setListeners">使用listeners调用父级方法</button>
    </div>
    <div>
      <el-input v-model="childStr" @input="confirm"></el-input>
      <button @click="confirm">修改v-model数据</button>
    </div>
    <div>
      <p>parent组件数据:{{ msg }}</p>
      <!-- 子组件child1-child -->
      <!-- <child1-child v-bind="$attrs" v-on="$listeners"></child1-child> -->
    </div>
  </div>
</template>
<script>
export default {
  props: {
    msg: {
      type: String,
      default: ''
    },
    // 通过v-model方式传值
    value: {
      type: String,
      default: ''
    }
  },
  data() {
    return {
      childStr: 'child String'
    };
  },
  inheritAttrs: false,
  mounted() {
    console.log('child1组件获取$attrs', this.$attrs);
    console.log('child1组件获取$listeners', this.$listeners);
  },
  methods: {
    // 我们在父组件中使用v-model向child2子组件传递数据,子组件的props中使用默认的value属性接收,
    // 在子组件中利用$emit触发父组件中默认input事件,此时传递的数据便会在子组件和父组件中发生变化,这就是数据双向绑定
    // 通过$emit触发父组件的input事件,并将第二个参数作为值传递给父组件
    confirm() {
      this.$emit('input', this.childStr);
    },

    // 点击按钮,使用$emit向父组件传递数据
    sendData() {
      this.$emit('childData', '我是子组件向父组件提交的数据');
    },
    // 通过$parent方式获取父组件值
    getParentData() {
      console.log('父组件', this.$parent);
    },
    //如果存在多层级组件,无需使用emit的方式逐级向上触发事件,只需要使用$listerners就可以得到父组件中的自定义事件
    setListeners() {
      this.$listeners.childData('通过listeners调用方法');
    }
  }
};
</script>
<style scoped>
.child-1 {
  border: 1px solid red;
}
</style>

?$attrs和$listeners的输出结果:

?

2、listeners属性和attrs属性类似,只是它们传递的东西不一样

?$listeners可以通过v-on的形式再次传递给下层组件,当父组件在子组件上定义了一些自定义的非原生事件时,在子组件内部可以通过listeners属性获取>父组件的自定义事件,它和attrs的区别很明显,attrs用来传递属性。

使用listeners的好处在于:如果存在多层级组件,无需使用emit的方式逐级向上触发事件,只需要使用$listerners就可以得到父组件中的自定义事件,相当于偷懒了。?

3、inheritAttrs

父组件传递了很多数据给子组件,子组件的props没有完全接收,那么父组件传递的这些数据就会渲染到HTML上,我们可以给子组件设置inheritAttrs 为false,避免这样渲染。

不设置inheritAttrs的属性如下

?设置inheritAttrs为false后

?

总结

attrs:用来会传递属性,除了class、style之类的,它是一个对象。 listeners:用来传递事件,除了原生事件,它也是一个对象。
attrs和listeners这两个属性可以解决多层组件之间数据和事件传递的问题。
inheritAttrs解决未使用props接收的数据的属性渲染

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-29 18:55:53  更:2022-06-29 18:56:20 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 10:02:54-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码