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

.

 前言

4c6769c0bad613e01bb0b72a1aa27f30.png

 爷组件

<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>

e3024e24f7110424691a6145e97b385a.png

父组件

<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>

d2f3c833ca9b5a175f38be2704a48be8.png

 孙组件

<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>

941af138dddafc191bfe20e51067b31b.png

 定义$attrs

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

ed009f1eed2dff4ab0c234c7e79aecc7.png

 运行结果

da3dd65a067b27543c92a9b7dba829d2.png

8c37d3908b2558572126be41ddaed876.png

定义$listeners

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

e9e113dfcadb296fb1616fdd482fdbf1.png

 运行结果 点击孙子组件

3027ac3de569f115fbba292097cc3921.png

68b90c90fd7f4de26f9827ad3078ecc0.png

 父组件

<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>

73020ef815334b56a95c4d9eab860e5d.png

 子组件

<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>

cedba1e9f0671b48e12627aa63cfada0.png

运行结果

a8b2aed3d6c5a7e0dad52a584007deef.png

大家好 我是歌谣 想和我一起学习前端加geyaoisnice

c4471473ea5f683a369d0c3daea8409b.png

点个在看你最好看

下方查看历史文章

6c4e8dc4217d1b58c8b6cdec85826843.png

vue2+luckyexcel+avue2解析在线网页数据

vue2+element基础架子2.0

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值