97国产精品视频人人做人人爱,3344在线观看无码,成年人国产视频,欧美日一级片,在线看AV天堂,高清无码一本到东京热,欧美一级黄片一区2区,免费又爽又刺激高潮网址

關于Vuex的全家桶狀態管理(二)

2018-5-28    seo達人

如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里

1:mutations觸發狀態 (同步狀態)

<template> <p class="hello"> <h1>Hello Vuex</h1> <h5>{{count}}</h5> <p> <button @click="jia">+</button> <button @click="jian">-</button> </p> </p> </template> <script> import {mapState,mapMutations} from 'vuex' export default{
  name:'hello', //寫上name的作用是,如果你頁面報錯了,他會提示你是那個頁面報的錯,很實用 //方法三 computed: mapState([ 'count' ]),
  methods:{
   ...mapMutations([ 'jia', 'jian' ])
  }
 } </script>
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26

2:getters計算屬性

getter不能使用箭頭函數,會改變this的指向

在store.js添加getters

 // 計算 const getters = {
  count(state){ return state.count + 66 }
} export default new Vuex.Store({
  state,
  mutations,
  getters
})
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

//count的參數就是上面定義的state對象 
//getters中定義的方法名稱和組件中使用的時候一定是一致的,定義的是count方法,使用的時候也用count,保持一致。 
組件中使用

<script> import {mapState,mapMutations,mapGetters} from 'vuex' export default{
  name:'hello',
  computed: {
   ...mapState([ 'count' ]),
   ...mapGetters([ 'count' ])
  },
  methods:{
   ...mapMutations([ 'jia', 'jian' ])
  }
 } </script>
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

3:actions (異步狀態)

在store.js添加actions

import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) // 定義常量 const state = { count: 1 } // mutations用來改變store狀態 同步狀態 const mutations = {
  jia(state){
    state.count ++
  },
  jian(state){
    state.count --
  },
} // 計算屬性 const getters = {
  count(state){ return state.count + 66 }
} // 異步狀態 const actions = {
  jiaplus(context){
    context.commit('jia') //調用mutations下面的方法
    setTimeout(()=>{
      context.commit('jian')
    },2000) alert('我先被執行了,然后兩秒后調用jian的方法') }, jianplus(context){ context.commit('jian') }
} export default new Vuex.Store({
  state,
  mutations,
  getters,
  actions
})
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44

在組件中使用

<template> <p class="hello"> <h1>Hello Vuex</h1> <h5>{{count}}</h5> <p> <button @click="jia">+</button> <button @click="jian">-</button> </p> <p> <button @click="jiaplus">+plus</button> <button @click="jianplus">-plus</button> </p> </p> </template> <script> import {mapState,mapMutations,mapGetters,mapActions} from 'vuex' export default{
  name:'hello',
  computed: {
   ...mapState([ 'count' ]),
   ...mapGetters([ 'count' ])
  },
  methods:{ // 這里是數組的方式觸發方法 ...mapMutations([ 'jia', 'jian' ]), // 換一中方式觸發方法 用對象的方式 ...mapActions({
    jiaplus: 'jiaplus',
    jianplus: 'jianplus' })
  }
 } </script> <style scoped> h5{ font-size: 20px; color: red; } </style>
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48

4:modules 模塊

適用于非常大的項目,且狀態很多的情況下使用,便于管理

修改store.js

import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const state = { count: 1 } const mutations = {
  jia(state){
    state.count ++
  },
  jian(state){
    state.count --
  },
} const getters = {
  count(state){ return state.count + 66 }
} const actions = {
  jiaplus(context){
    context.commit('jia') //調用mutations下面的方法
    setTimeout(()=>{
      context.commit('jian')
    },2000) alert('我先被執行了,然后兩秒后調用jian的方法') }, jianplus(context){ context.commit('jian') }
}

//module使用模塊組的方式 moduleA const moduleA = { state, mutations, getters, actions }

// 模塊B moduleB const moduleB = { state: { count:108
  }
} export default new Vuex.Store({
  modules: {
    a: moduleA,
    b: moduleB,
  }
})
藍藍設計www.0391cbd.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務

日歷

鏈接

個人資料

藍藍設計的小編 http://www.0391cbd.com

存檔

主站蜘蛛池模板: 免费一看一级毛片| av在线人妻熟妇| 日韩精品亚洲一区中文字幕| 亚洲天堂.com| 精品久久国产综合精麻豆| 丝袜国产一区| 91久久国产综合精品| 凹凸国产分类在线观看| 热久久综合这里只有精品电影| 久久久久久久久亚洲精品| 国产亚洲现在一区二区中文| 国产精品久久久久久影院| 久久99国产综合精品1| 色屁屁一区二区三区视频国产| 成年网址网站在线观看| 人妻精品全国免费视频| 国国产a国产片免费麻豆| 国产爽歪歪免费视频在线观看| 亚洲欧洲日韩综合色天使| 亚洲国产成人久久精品软件| 国产av一码二码三码无码| 国产乱子伦视频在线播放| 欧美中文字幕无线码视频| 日本伊人色综合网| 十八禁美女裸体网站| 老司机久久99久久精品播放| 毛片视频网址| 国产成人精品18| 日本三级精品| 亚洲欧美不卡视频| 亚洲欧美另类久久久精品播放的| 久久亚洲国产最新网站| 国产精品分类视频分类一区| 一区二区日韩国产精久久| 午夜色综合| 亚洲一级毛片在线观播放| 中文字幕天无码久久精品视频免费| 欧美在线导航| 亚洲天堂777| 亚洲永久色| 国产欧美性爱网| 91色老久久精品偷偷蜜臀| 一级毛片在线免费视频| 一级毛片不卡片免费观看| 直接黄91麻豆网站| 性做久久久久久久免费看| 99热这里都是国产精品| 国产sm重味一区二区三区| 国产日本一线在线观看免费| 99青青青精品视频在线| 九九九九热精品视频| 国产激情无码一区二区APP | 国产精选小视频在线观看| 国产精品55夜色66夜色| 波多野结衣爽到高潮漏水大喷| 亚洲国产成人自拍| 国产精品永久在线| 草草线在成年免费视频2| 午夜欧美理论2019理论| 日韩一区二区三免费高清| 久久久久久久久久国产精品| 国产精品黑色丝袜的老师| 国产免费一级精品视频| 国产精品亚洲一区二区在线观看| 午夜视频在线观看区二区| 亚洲午夜综合网| 日韩国产高清无码| 最近最新中文字幕在线第一页| 国产精品久久久精品三级| 狠狠v日韩v欧美v| 亚洲第一色网站| 九色91在线视频| 色窝窝免费一区二区三区 | 久久综合色天堂av| 国产欧美日韩精品综合在线| 女同国产精品一区二区| 青青青国产精品国产精品美女| www欧美在线观看| 亚洲欧美另类日本| 国产成人精品免费视频大全五级| 亚洲天堂视频网站| 园内精品自拍视频在线播放|