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尤物在線觀看| 亚洲成A人V欧美综合| 热久久国产| 91在线一9|永久视频在线| 亚洲动漫h| 日韩精品中文字幕一区三区| 婷婷六月天激情| 青青草原国产精品啪啪视频| 亚洲无码免费黄色网址| 香蕉国产精品视频| 无码AV日韩一二三区| 国产免费精彩视频| 亚洲第一极品精品无码| 视频国产精品丝袜第一页| 免费xxxxx在线观看网站| 91麻豆精品视频| 亚洲欧美自拍视频| 欧美日韩在线国产| 国产超薄肉色丝袜网站| 国产精品久久自在自线观看| 国产在线一区视频| 免费精品一区二区h| 伊人色天堂| 国产极品粉嫩小泬免费看| 国产黄色免费看| 国产成年无码AⅤ片在线| 国产精品免费露脸视频| 91久久偷偷做嫩草影院精品| 国产一级做美女做受视频| 91网在线| 亚洲天堂高清| aaa国产一级毛片| 一级全黄毛片| 永久在线播放| 国产人成乱码视频免费观看| 久久综合伊人 六十路| 国产精彩视频在线观看| 97精品国产高清久久久久蜜芽 | 中文字幕一区二区人妻电影| 91精品网站| 香蕉伊思人视频| 日韩高清在线观看不卡一区二区| 国产无码网站在线观看| 国产精品香蕉在线| 福利国产在线| 伊人成色综合网| 日本成人在线不卡视频| 国产欧美日韩在线一区| 久久频这里精品99香蕉久网址| 中日韩一区二区三区中文免费视频| 一级毛片高清| 永久天堂网Av| 熟妇丰满人妻| 天天躁夜夜躁狠狠躁躁88| 国产男女免费视频| 国产精品yjizz视频网一二区| 激情無極限的亚洲一区免费| 免费高清自慰一区二区三区| 国产av无码日韩av无码网站| 亚洲午夜福利在线| 亚洲日韩精品无码专区97| 成人精品视频一区二区在线| 成AV人片一区二区三区久久| 欧美中文字幕一区二区三区| 日韩毛片免费观看| 丝袜无码一区二区三区| 91午夜福利在线观看精品| 99在线国产| 一级成人欧美一区在线观看| 国产欧美日韩资源在线观看| 亚洲VA中文字幕| 91精品国产综合久久香蕉922| 欧美性天天| 91亚洲国产视频| 国产精品尤物在线| 无码精品福利一区二区三区|