vuex獲取state對(duì)象中值的所有方法小結(jié)(module中的state)
vuex獲取state對(duì)象中的值
直接從store實(shí)例取值
// main.js中,把store注冊(cè)在根實(shí)例下,可使用this.$stroe.state直接取值
export default {
? computed: {
? ? testNum() {
? ? ? return this.$store.state.testNum;
? ? }
? }
};
使用mapState取值的多種方法
import { mapState } from "vuex";export default {
? data() {
? ? return { localNum: 1 };
? },
? computed: {
? ? ...mapState({
? ? ? // 箭頭函數(shù)使代碼更簡(jiǎn)練
? ? ? testNum1: state => state.testNum1,
? ? ? // 傳字符參數(shù)'testNum2' 等價(jià)于 'state => state.testNum2'
? ? ? testNum2: "testNum2",
? ? ? // 組件的局部變量與Vuex變量相加
? ? ? testNum3(state) {
? ? ? ? return state.testNum1 + this.localNum;
? ? ? }
? ? }),
? ? ...mapState([
? ? ? // 映射this.testNum3為store.state.testNum3
? ? ? "testNum3"
? ? ])
? }
};使用module中的state
import { mapState } from "vuex";
export default {
? computed: {
? ? ...mapState({
? ? ? // 箭頭函數(shù)使代碼更簡(jiǎn)練
? ? ? testNum1: state => state.moduleA.testNum1
? ? }),
? ? // 第一個(gè)參數(shù)是namespace命名空間,填上對(duì)應(yīng)的module名稱即可
? ? ...mapState("moduleA", {
? ? ? testNum2: state => state.testNum2,
? ? ? testNum3: "testNum3"
? ? }),
? ? ...mapState("moduleA",[
? ? ? "testNum4"
? ? ])
? }
};vuex調(diào)用state數(shù)據(jù)
第一種
直接訪問 <h1>姓名:{{$store.state.msg}}</h1>
第二種:利用計(jì)算屬性
將想要用到的全局state數(shù)據(jù),防止到組件的computed內(nèi)部使用,v-model的內(nèi)容將其獲取和設(shè)置分開即可
<h1>姓名:{{msg}}</h1>
<h1>年齡:{{age}}</h1>
<h1>數(shù)字:{{num}}</h1>
<input type="text" v-model="num">
computed: {
????????age:function(){??//msg也相同,就沒寫
????????????return this.$store.state.age
????????},
????????num:{
????????????get:function(){
????????????????return this.$store.state.num;
????????????},
????????????set:function(num){?? //數(shù)據(jù)雙向綁定
????????????????this.$store.commit('setNum',num)
????????????}
????????}
????},第三種:mapstate 數(shù)組
<h1>姓名:{{msg}}</h1>
<h1>年齡:{{age}}</h1>
<h1>數(shù)字:{{num}}</h1>
<input type="text" :value="num" @input="changeVal" >
import { mapState } from 'vuex'??//需要引入mapState
computed:mapState(['age','msg','num']),
????methods: {??
????????changeVal(e){????//設(shè)置值
????????????return this.$store.commit('setNum',e.target.value)
????????}
????},第四種:mapState 對(duì)象
<h1>姓名:{{msg}}</h1>
<h1>年齡:{{age}}</h1>
<h1>數(shù)字:{{num}}</h1>
import { mapState } from 'vuex'??//需要引入mapState
computed:mapState({
????????msg:'msg',
????????num:'num',
????????// age:(state)=>state.age,?? //不需要大括號(hào)的時(shí)候,就不需要用 return 返回值
????????age:(state)=>{ return state.age},
????})第五種:mapState 對(duì)象 解構(gòu) 追加變量
<h1>姓名:{{msg}}</h1>
<h1>年齡:{{age}}</h1>
<h1>數(shù)字:{{num}}</h1>
import { mapState } from 'vuex'
let objMapState=mapState({
????????msg:'msg',
????????num:'num',
????????// age:(state)=>state.age,
????????age:function(state){ return this.greenColor+state.age},
????})
data() {
????????return {
????????????greenColor:'blue'????????????
????????}
????},
computed:{
????????...mapState(objMapState)
????}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue項(xiàng)目打包之后生成一個(gè)可修改IP地址的文件(具體操作)
這篇文章主要介紹了vue項(xiàng)目打包之后生成一個(gè)可修改IP地址的文件(具體操作),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03
vue+el-table實(shí)現(xiàn)合并單元格
這篇文章主要為大家詳細(xì)介紹了vue+el-table實(shí)現(xiàn)合并單元格,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
vue組件實(shí)現(xiàn)發(fā)表評(píng)論功能
這篇文章主要為大家詳細(xì)介紹了vue組件實(shí)現(xiàn)發(fā)表評(píng)論功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
解決Vue不能檢測(cè)數(shù)組或?qū)ο笞儎?dòng)的問題
下面小編就為大家分享一篇解決Vue不能檢測(cè)數(shù)組或?qū)ο笞儎?dòng)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-02-02
vue實(shí)現(xiàn)倒計(jì)時(shí)功能
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)倒計(jì)時(shí)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-03-03

