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

日歷

鏈接

個人資料

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

存檔

主站蜘蛛池模板: 国产精品女人呻吟在线观看| 波多野结衣中文字幕一区二区| 色偷偷一区二区三区| 国产性生大片免费观看性欧美| 视频一本大道香蕉久在线播放| 日韩视频免费| 日韩专区第一页| 91精品国产无线乱码在线| 亚洲国产精品无码久久一线| 国产午夜一级毛片| …亚洲 欧洲 另类 春色| 亚洲成av人无码综合在线观看| 亚洲一区二区日韩欧美gif| 亚洲福利网址| 好紧太爽了视频免费无码| 亚洲成人播放| 中文字幕中文字字幕码一二区| 亚洲高清在线天堂精品| 国产网站在线看| 国产成人久视频免费| 91在线精品免费免费播放| 国产网友愉拍精品视频| 在线观看国产黄色| 天天综合网色| 丝袜高跟美脚国产1区| 伊人精品成人久久综合| 97久久超碰极品视觉盛宴| 久久99国产精品成人欧美| 亚洲无码日韩一区| 九色在线观看视频| 91精品国产麻豆国产自产在线| 色婷婷亚洲综合五月| 伊人色在线视频| 国产九九精品视频| 亚洲综合欧美在线一区在线播放| 国产在线91在线电影| 精品天海翼一区二区| 日韩在线成年视频人网站观看| 欧美精品啪啪一区二区三区| 东京热一区二区三区无码视频| 国产综合色在线视频播放线视| 欧美亚洲香蕉| 极品国产在线| 一本大道东京热无码av| av在线5g无码天天| 色久综合在线| 三上悠亚精品二区在线观看| 99精品这里只有精品高清视频| 精品人妻一区二区三区蜜桃AⅤ| 亚洲成人一区在线| 久久婷婷人人澡人人爱91| 综合天天色| 国产一区二区三区在线精品专区| 久久人人爽人人爽人人片aV东京热| 欧美成人精品欧美一级乱黄| 欧美国产日韩在线播放| 国产一区二区精品福利| 麻豆国产精品| 性视频一区| 青青草91视频| 99视频有精品视频免费观看| 中文精品久久久久国产网址| 成人小视频在线观看免费| 精品夜恋影院亚洲欧洲| 在线观看欧美国产| 免费一级毛片完整版在线看| 色综合天天视频在线观看| 中文无码毛片又爽又刺激| а∨天堂一区中文字幕| 亚洲无码高清视频在线观看| 久久精品这里只有国产中文精品| a毛片免费观看| 久久亚洲高清国产| 亚洲欧美日韩动漫| 日韩在线网址| 国产激爽大片在线播放| 国产欧美日韩91| www.国产福利| 中文字幕色在线| 国产在线精彩视频论坛| 欧美成人精品在线| 午夜视频日本|