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

存檔

主站蜘蛛池模板: 久久久国产精品无码专区| 伊人久久久大香线蕉综合直播| 欧美成人日韩| 99精品免费欧美成人小视频| 欧美日韩免费| 成人在线亚洲| 国产女人18毛片水真多1| 色网站免费在线观看| 在线国产综合一区二区三区| 日韩专区第一页| 日本人妻一区二区三区不卡影院 | 欧美在线一二区| 亚洲成人一区在线| 在线欧美日韩国产| 久久网欧美| 成人在线综合| 国产成人AV男人的天堂| 国产最爽的乱婬视频国语对白| 九色在线视频导航91| www.亚洲色图.com| 久久永久免费人妻精品| 欧美一级99在线观看国产| 在线观看亚洲人成网站| 国产乱人伦精品一区二区| 天堂av高清一区二区三区| 妇女自拍偷自拍亚洲精品| 国产91麻豆视频| 99久久精品国产精品亚洲| 国产日本一区二区三区| 99九九成人免费视频精品| 欧美色视频在线| 男女猛烈无遮挡午夜视频| 丰满少妇αⅴ无码区| 影音先锋丝袜制服| 欧美性久久久久| 亚洲第一香蕉视频| 中文字幕亚洲电影| 伊人中文网| 国产精品三级专区| 91青青在线视频| 中文字幕无码av专区久久| 久久国产乱子伦视频无卡顿| 91免费国产高清观看| 国产靠逼视频| 97色婷婷成人综合在线观看| 无码专区国产精品一区| 国产在线观看人成激情视频| 亚洲欧美日韩久久精品| 狠狠色丁香婷婷| 在线国产91| 熟女日韩精品2区| 亚洲伦理一区二区| 狠狠做深爱婷婷久久一区| 久久99国产综合精品1| 国产主播在线一区| 亚洲精选高清无码| 青青热久免费精品视频6| 日韩美毛片| 日韩国产黄色网站| 亚洲日本中文字幕乱码中文| 黄色网址免费在线| 亚洲无线一二三四区男男| 久久久精品久久久久三级| 国产精品永久在线| 日韩欧美中文字幕一本| 91在线播放国产| 婷婷六月在线| 专干老肥熟女视频网站| 天天综合天天综合| 久久青青草原亚洲av无码| 国产精品主播| 四虎在线观看视频高清无码 | 国产成人AV综合久久| 小蝌蚪亚洲精品国产| 97超级碰碰碰碰精品| 欧美性猛交一区二区三区| 亚洲二区视频| 亚洲色欲色欲www在线观看| 国产精品成人免费视频99| 国产精品成人久久| 高清精品美女在线播放| 波多野结衣久久高清免费|