vue 组件传值常用5种

vue 组件传值

1、父组件给子组件传值

父组件:
<template>
   <child :name="name"></child>
</template>
<script>
import child from "./child.vue"
  export default {
     components: {child},
     data(){
      return {name:"二哈"}
     }
  }
</script>
子组件:

<template>
  <div>{{name}}</div>
</template>
<script>
  export default {
    props:["name"]
    或者:props:{
	    name:{
	    }
    }
  }
</script>

. 2. 子组件给父组件

父组件:

<template>
  <child @childToParent="reviceSondata"></child>
</template>
<script>
import child from "./child.vue"
  export default {
    components: {child},
    methods:{
      reviceSondata(data){
        console.log(data);
      }
    }
  }
</script>
子组件:

<template>
   <button @click="dataTofather">点击</button>
</template>
<script>
  export default {
    data () {
      return {
        message: '啦啦啦啦'
      }
    },
    methods:{
      dataTofather(){
        this.$emit("childToParent",this.message,true);
      }
    }
  }
</script>

3、vuex

store.js:

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

const store = new Vuex.Store({
  // 定义状态
  state: {
    headImg: JSON.parse(sessionStorage.getItem('headImg')) || ""
  },
  mutations: {
    newImg(state, msg){
      sessionStorage.setItem('headImg', JSON.stringify(msg))
      state.headImg = msg;
    }
  }
})

export default store
main.js中引入vuex

import Vue from 'vue';
import Vuex from 'vuex';
import store from './vuex/store';
Vue.use(Vuex);
var v = new Vue({
  el: '#app',
  router,
  store,
  components: {index},
  template: '<index/>',
  created: function () {

  }
})

传值:this.$store.commit("newImg", value);
取值:this.$store.state.headImg
  1. 中央bus总线
    原理上就是建⽴立⼀一个公共的js⽂文件,专⻔门⽤用来传递消息
bus.js

import Vue from 'vue'
const Bus = new Vue();
export default Bus;

在需要传递消息的地⽅方引⼊入

mport Bus from './util/bus'
methods: {
  passMsg () {
    Bus.$emit('msg', 'i am from app')
  }
},
   传递消息,在需要接受消息的地方使用bus.$on接受消息

mounted () {
    Bus.$on('msg', (val) => {
      this.childMsg = val
    });

5.provide和inject使用
常用的父子组件通信方式都是父组件绑定要传递给子组件的数据,子组件通过props属性接收,一旦组件层级变多时,采用这种方式一级一级传递值非常麻烦,而且代码可读性不高,不便后期维护。

vue提供了provide和inject帮助我们解决多层次嵌套嵌套通信问题。在provide中指定要传递给子孙组件的数据,子孙组件通过inject注入祖父组件传递过来的数据。

//父组件
import Child from './Child'
export default {
  name: 'Parent',
  //传递的数据
  provide: {
  
	nameFromParent: 'Kevin'
  }
  components: {
    Child
  }
}
//所有子组件,包括孙组件
data() {
            return {
                name: 'Two sons',
                msg:'',
            }
        },
        inject:['nameFromParent'],
        mounted(){
            this.msg = this.nameFromParent;
        }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 13
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值