<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • 關于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.sdgs6788.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務

          日歷

          鏈接

          個人資料

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

          存檔

          91久久精品视频| 伊人久久大香线蕉成人| 久久国产美女免费观看精品| 亚洲国产精品久久久久| 精品久久久久久国产| 日本三级久久网| 亚洲精品无码成人片久久| 久久99国产一区二区三区| 一本色道久久88—综合亚洲精品| 久久精品国产亚洲综合色| 亚洲国产欧美国产综合久久| 久久亚洲中文字幕精品一区四| 欧美黑人又粗又大久久久| 久久久久国产| 国产精品美女久久久久AV福利 | 久久精品www| A狠狠久久蜜臀婷色中文网| 久久精品视频一| 久久久久国产一区二区| 色综合久久最新中文字幕| 99国产精品久久久久久久成人热| 7777精品久久久大香线蕉| 美女久久久久久| 久久99精品久久久久久9蜜桃| 精品午夜久久福利大片| 国产成人精品久久二区二区| 欧美噜噜久久久XXX| 亚洲AV无码久久精品成人| 国产亚洲精久久久久久无码77777 国产亚洲精品久久久久秋霞 | 精品久久久久久无码中文字幕 | 久久精品中文字幕无码绿巨人| 欧美午夜A∨大片久久| 久久婷婷五月综合成人D啪| 精品久久久久久久久久久久久久久 | 国产高潮国产高潮久久久| 久久精品亚洲一区二区三区浴池| 日韩精品久久无码人妻中文字幕| 无码人妻久久一区二区三区免费 | 欧美精品乱码99久久蜜桃| 久久综合视频网| 少妇久久久久久久久久|