前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue2中的$attrs和$listener和provide和inject

Vue2中的$attrs和$listener和provide和inject

作者头像
爱学习的前端歌谣
发布2024-05-30 20:34:54
740
发布2024-05-30 20:34:54
举报
文章被收录于专栏:前端小歌谣

前言

爷组件

代码语言:javascript
复制
<template>
  <div class="page-all">
    爷爷组件
    <B :msg1="msg1" :msg2="msg2" @method1="handleClick" @method2="handleClick"></B>
  </div>
</template>


<script>
import B from "./views/Bpp.vue"


export default {
  name: "App",
  data() {
    return {
      msg1: "歌谣爱你呀1",
      msg2: "歌谣爱你呀2",
    }
  },
  components: { B },
  methods: {
    handleClick() {
      console.log('爷爷组件')
    }
  },
  mounted() { },
}
</script>

父组件

代码语言:javascript
复制
<template>
    <div class="page-all">
      父亲组件
      <p>$attrs: {{ $attrs }}</p>
      <div @click="handleAClick">handleAClick: {{ msg1 }}</div>
      <Cpp v-bind="$attrs" v-on="$listeners"></Cpp>
    </div>
  </template>
  
  <script>
  import Cpp from "./Cpp.vue"
  
  export default {
    name: "B",
    props: ['msg1'],
    data() {
      return {}
    },
    components: {Cpp},
    methods: {
      handleAClick() {
        console.log(this.$listeners,"父亲组件")
        console.log('父亲组件')
        this.$emit('method1')
      }
    },
    mounted() {},
  }
</script>
  

孙组件

代码语言:javascript
复制
<template>
    <div class="page-all">
      孙子组件
      <p>$attrs: {{ $attrs }}</p>
      <div @click="handleCClick">handleClick: {{ msg1 }}{{ msg2 }}</div>
    </div>
  </template>
  
  <script>
  export default {
    name: "C",
    props: ['msg1', 'msg2'],
    data() {
      return {}
    },
    components: {},
    methods: {
      handleCClick() {
        console.log(this.$listeners,"孙子组件")
        console.log('孙子组件')
        this.$emit('method2')
      }
    },
    mounted() {},
  }
</script>
  

定义$attrs

代码语言:javascript
复制
  当一个组件没有声明任何 prop 时,$attrs会包含所有父作用域的绑定 
  (class 和 style 除外),并且可以通过 v-bind="$attrs" 传入内部
  组件,一般用在子组件的子元素上

运行结果

定义$listeners

代码语言:javascript
复制
  包含了父作用域中的 (不含 .native 修饰器的) v-on 事件监听器。
  它可以通过 v-on="$listeners" 传入内部组件

运行结果 点击孙子组件

父组件

代码语言:javascript
复制
<template>
  <div>
    <HelloGeyao></HelloGeyao>
  </div>
</template>
<script>
import HelloGeyao from "../src/views/HelloGeyao.vue"
export default {
  data(){
    return{
      msg:"geyao",
    }
   
  },
  components:{
    HelloGeyao
  },
  provide: function () {
    return {
      geyao: this.getGeyao // 把当前Vue对象提供给所有子组件可以访问
    }
  },
  methods:{
    getGeyao(){
      return this.msg
    }
  }
}
</script>

子组件

代码语言:javascript
复制
<template>
    <div class="container">
       geyao
    </div>
</template>


<script>
export default {
    inject:['geyao'],
    data() {
        return {


        }
    },
    mounted() {
        this.createLineChart()
    },
    methods: {
        createLineChart() {
            console.log(this.geyao(),"data is")
        }
    },
    components: {


    }
}
</script>


<style scoped lang="scss"></style>

运行结果

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-05-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端小歌谣 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档