Vue - 組件傳值

一.基本傳值方法 props/$emit

首先,我們從組件開始,導(dǎo)入子組件(進(jìn)行注冊(cè)).

import recruitSwiper from "@/components/recruit/recruit-swiper.vue"
export default {
    components: {
        recruitItem
    },
    data() {
        return {}
    }
}

將注冊(cè)好的子組件應(yīng)用至父組件,通過屬性綁定 :info="xxx",進(jìn)行 父>子 值傳遞

<recruitItem :info="xxx"></recruitItem>

到子組件里面,用 props 接收

export default {
    props: {
        Info: {
            type: Array
        }
    }
}
//接下來進(jìn)行遍歷即可
<block v-for="(info,index) in Info" :key="index"></block>

子組件向父組件傳值,要運(yùn)用 $emit 進(jìn)行發(fā)射

export default {
    props: {
        Info: {
            type: Array
        }
    },
    methods: {
        sendTask(e) {
            this.$emit("sendTask", e) // (方法名,參數(shù))
        }
    }
}

接收之前定義的方法名 (sendTask)

<recruit-item :info="xxx" @sendTask="sendTask"></recruit-item>
//這里定義方法
methods: {
    sendTask(e) {
      console.log(e)
    }
}

這就是基本的父子組件傳值了.


二.vuex傳值

以下例子來源于vuex官方

首先使用npm進(jìn)行安裝

npm i vuex -g
npm i vuex -S

靜態(tài)目錄src下新建一個(gè)sotre/index.js這就是你的倉庫了

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

Vue.use(Vuex)

const store = new Vuex.Store({
    state: {
        url: "xxx"
    },
    getters: {},
    mutations: {},
    modules: {}
})
export default store;

入口文件mian.js進(jìn)行全局注冊(cè),現(xiàn)在就綁在vue原型上了

import store from './store'
    Vue.prototype.$store = store;//后面可以直接使用 this.$store
};

改變url的值,直接改this.$store.state.url="new",可以變化.但根據(jù)官方說法,最好使用commit進(jìn)行值的變更.

// store/index.js
const store = new Vuex.Store({
    state: {
        url: "xxx"
    },
    mutations: {
        setUrl(state,value) {
            state.url = value // 變更
    }
})
export default store;


//sub.vue
this.$store.state.url //值的獲取
this.$store.commit("setUrl","newUrl") //值的更改

三.在Vue的屬性綁定:bind中,綁定的類型不僅僅是數(shù)組/對(duì)象等.也可以是函數(shù),例如一下例子;

下述方法主要運(yùn)用過程,父組件中傳遞給子組件函數(shù)方法,子組件調(diào)用.

// 父組件
<template>
  <div :useFunction="usedFunction"></div>
</template>

<script>
  data(){
    return{
      name:'xixi'
    }
  },
  methods(){
    useFunction(request){
      this.name = request;
    }
  }
</script>

// 子組件
<template>
  <div @click="useModule"></div>
</template>

<script>
  props:{    
    usedFunction:{
      type:Function
    }
  },
  methods(){
    useModule(){
      this.usedFunction('test')
    }
  }
</script>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 目前流行組件化開發(fā),vue組件間傳值是一個(gè)非常常用的功能,有時(shí)候僅僅是父子和兄弟之間簡(jiǎn)單的傳值,我們就沒有必要直接...
    西域戰(zhàn)神閱讀 4,516評(píng)論 1 3
  • https://blog.csdn.net/qq_41696819/article/details/8143140...
    情話_2ee5閱讀 401評(píng)論 0 1
  • 清風(fēng)細(xì)雨幾度涼,花香雁排一帆揚(yáng)。 坐看妖嬈云煙開,一筆落下詩千行。
    筆下風(fēng)流怎知言可畏閱讀 302評(píng)論 0 1
  • 從愚人節(jié)至現(xiàn)在4.10號(hào)整整10天,我就這樣毫無目的的生存。吃飯,睡覺,玩手機(jī),明明知道這樣的自己太過頹廢,...
    喜歡me閱讀 279評(píng)論 0 1
  • 好像有那么一點(diǎn)開始焦慮了。好像有那么一點(diǎn)開始自暴自棄了。好像有那么一點(diǎn)想放棄了。說不上為啥。無論哪個(gè)方面都不美好。...
    炸裂的啊哈閱讀 138評(píng)論 0 1

友情鏈接更多精彩內(nèi)容