欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何快速入門Vuex

本篇文章為大家展示了如何快速入門Vuex,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

創(chuàng)新互聯(lián)公司成立于2013年,是專業(yè)互聯(lián)網(wǎng)技術服務公司,擁有項目成都做網(wǎng)站、成都網(wǎng)站建設網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元自流井做網(wǎng)站,已為上家服務,為自流井各地企業(yè)和個人服務,聯(lián)系電話:028-86922220

一、前言

當我們的應用遇到多個組件共享狀態(tài)時,會需要多個組件依賴于同一狀態(tài)。傳參的方法對于多層嵌套的組件將會非常繁瑣,并且對于兄弟組件間的狀態(tài)傳遞無能為力。在搭建下面頁面時,你可能會對 vue 組件之間的通信感到崩潰 ,特別是非父子組件之間通信。此時就應該使用vuex,輕松可以搞定組件間通信問題。

如何快速入門Vuex 

二、什么是Vuex

Vuex 是一個專為 Vue.js 應用程序開發(fā)的狀態(tài)管理模式。它采用集中式存儲管理應用的所有組件的狀態(tài),并以相應的規(guī)則保證狀態(tài)以一種可預測的方式發(fā)生變化。這里的關鍵在于集中式存儲管理。 這意味著本來需要共享狀態(tài)的更新是需要組件之間通訊的,而現(xiàn)在有了vuex,就組件就都和store通訊了 。

三、什么時候使用Vuex

雖然 Vuex 可以幫助我們管理共享狀態(tài),但也附帶了更多的概念和框架。這需要對短期和長期效益進行權衡。 如果您的應用夠簡單,您最好不要使用 Vuex,因為使用 Vuex 可能是繁瑣冗余的。一個簡單的global event bus就足夠您所需了。但是, 如果您需要構建一個中大型單頁應用,您很可能會考慮如何更好地在組件外部管理狀態(tài),Vuex 將會成為自然而然的選擇。

四、Vuex安裝(限定開發(fā)環(huán)境為 vue-cli)

首先要安裝vue-cli腳手架,對于大陸用戶,建議將npm的注冊表源設置為國內(nèi)的鏡像(淘寶鏡像),可以大幅提升安裝速度。

npm config set registry https://[registry.npm.taobao.org](http://registry.npm.taobao.org/)
npm config get registry//配置后可通過下面方式來驗證是否成功
npm install -g cnpm --registry=[https://registry](https://registry/).npm.taobao.org
//cnpm安裝腳手架
cnpm install -g vue-cli
vue init webpack my-vue
cd my-vue
cnpm install
cnpm run dev

腳手架安裝好后,再安裝vuex

cnpm install vuex --save

 五、如何使用Vuex

1.如何通過Vuex來實現(xiàn)如下效果?

如何快速入門Vuex 

①創(chuàng)建一個store.js文件

import Vue from "vue"
import Vuex from "vuex"
Vue.use(Vuex)
const store = new Vuex.Store({
 state: { //這里的state必須是JSON,是一個對象
 count: 1 //這是初始值
 },
 mutations: {//突變,羅列所有可能改變state的方法
 add(state) {
  state.count++; //直接改變了state中的值,而并不是返回了一個新的state
 },
 reduce(state){
  state.count--;
 }
 }
});
export default store;//用export default 封裝代碼,讓外部可以引用

②在main.js文件中引入store.js文件

import store from "./vuex/store"
new Vue({
 router,
 store,
 el: '#app',
 render: h => h(App)
})

③新建一個模板count.vue

<template>
 <div>
  <h3>{{msg}}</h3><hr/>
  <h3>{{$store.state.count}}-{{count}}</h3>//這兩種寫法都可以
  <button @click="addNumber">+</button>
  <button @click="reduceNumber">-</button>
 </div>
</template>
<script>
import {mapState} from 'vuex'
export default {
 data() {
 return {
  msg: "Hello Vuex"
 };
 },
 methods: {
 addNumber() {
  return this.$store.commit("add");
 },
 reduceNumber() {
  return this.$store.commit("reduce");
 }
 },
 computed: mapState(['count'])// 映射 this.count 到 this.$store.state.count
         mapState 函數(shù)可以接受一個對象,也可以接收一個數(shù)組
};
</script>

由于 store 中的狀態(tài)是響應式的,當 Vue 組件從 store 中讀取狀態(tài)的時候,若 store 中的狀態(tài)發(fā)生變化,那么相應的組件也會相應地得到高效更新。 在組件中調(diào)用 store 中的狀態(tài)簡單到僅需要在計算屬性中返回即可。改變store 中的狀態(tài)的唯一途徑就是顯式地提交 (commit) mutations。

這樣,我們就可以實現(xiàn)自增1或是自減1,那假如我們想要點擊一次實現(xiàn)自增2,這該如何實現(xiàn),也就是如何向Mutations傳值?

2.如何在Mutations里傳遞參數(shù)

先store.js文件里給add方法加上一個參數(shù)n

mutations: {
 add(state,n) {
  state.count+=n;
 },
 reduce(state){
  state.count--;
 }
 }

然后在Count.vue里修改按鈕的commit( )方法傳遞的參數(shù)

addNumber() {
  return this.$store.commit("add",2);
 },
 reduceNumber() {
  return this.$store.commit("reduce");
 }

3.getters如何實現(xiàn)計算過濾操作

getters從表面是獲得的意思,可以把他看作在獲取數(shù)據(jù)之前進行的一種再編輯,相當于對數(shù)據(jù)的一個過濾和加工。你可以把它看作store.js的計算屬性。

例如:要對store.js文件中的count進行操作,在它輸出前,給它加上100。

首先要在store.js里Vuex.Store()里引入getters

getters:{
  count:state=>state.count+=100
 }

然后在Count.vue中對computed進行配置,在vue 的構造器里邊只能有一個computed屬性,如果你寫多個,只有最后一個computed屬性可用,所以要用展開運算符”…”對上節(jié)寫的computed屬性進行一個改造。

computed: {
 ...mapState(["count"]),
 count() {
  return this.$store.getters.count;
 }
 }

需要注意的是,此時如果點擊'+',就會增加102,如果點擊'-',就會增加99,最后的結果是mutations和getters共同作用的。

4.actions如何實現(xiàn)異步修改狀態(tài)

actions和上面的Mutations功能基本一樣,不同點是, actions是異步的改變state狀態(tài),而Mutations是同步改變狀態(tài) 。

①在store.js中聲明actions

actions: {
 addAction(context) {
  context.commit('add', 2);//一開始執(zhí)行add,并傳遞參數(shù)2
  setTimeout(() => {
  context.commit('reduce')
  }, 2000);//兩秒后會執(zhí)行reduce
  console.log('我比reduce提前執(zhí)行');
 },
 reduceAction({
  commit
 }) {
  commit('reduce')
 }
 }

actions是可以調(diào)用Mutations里的方法的,調(diào)用add和reduce兩個方法。在addAction里使用setTimeOut進行延遲執(zhí)行。在actions里寫了兩個方法addAction和reduceAction,兩個方法傳遞的參數(shù)也不一樣。

context:上下文對象,這里你可以理解稱store本身。 {commit}:直接把commit對象傳遞過來,可以讓方法體邏輯和代碼更清晰明了

②模板中的使用

<p>
 <button @click="addNumber">+</button>
 <button @click="reduceNumber">-</button>
</p>
<p>  
 <button @click="addAction">+</button>//新增
 <button @click="reduceAction">-</button>//新增
</p>
import { mapState, mapGetters, mapActions } from "vuex";
methods:{
 ...mapMutations([ 
  'add','reduce'
 ]),
 ...mapActions(['addAction','reduceAction'])
}

最后得到如下效果:點擊addAction按鈕事件時,先累加2,兩秒后再減去1,而addNumber事件則不能實現(xiàn)異步效果。

如何快速入門Vuex

上述內(nèi)容就是如何快速入門Vuex,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)頁題目:如何快速入門Vuex
文章起源:http://aaarwkj.com/article32/igeepc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站、軟件開發(fā)品牌網(wǎng)站設計、網(wǎng)站設計、虛擬主機網(wǎng)站營銷

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設公司
亚洲乱码一区二区免费版| 成人日韩av免费在线观看| 国产三级国产精品国产| 色六月婷婷六月久久六月| 97在线资源视频播放| 中文字幕熟女av一区二区| 亚洲欧洲一区二区免费| 我的农村中年激情熟妇| 亚洲一区精品二人人爽久久| 亚洲一区二区三区精品乱码 | 白小白的视频在线观看| 国产一区二区三区不卡视频 | 男女性情视频免费大全网站| 男人的天堂成人午夜视频| 97超碰97资源在线| 精品熟女少妇av免费观看| 黄色成人av在线网站| 国产三级自拍视频在线观看| 日韩高清一级黄色大片网站| 久久综合给合综合久久| 国产91九色在线播放| 日本五十路亲子在线一区| 溪乱毛片一区二区三区| 成人三级中文字幕电影| 国产原创av超爽剧情系列| 中文字幕在线精品乱码| 亚洲一区制服无码中文| 国产内射一级一片内射高清视频1 亚洲一区二区三区不卡伦理 | 日韩在线一区二区视频观看| 蜜臀av人妻一区二区三区| 91超碰这里只有精品国产| 熟年人妻一区二区三区| 91一区二区亚洲嫩草| 黑人一区二区三区在线| 国产精品国产成人免费看| 国产自拍精品视频免费观看| 久久免费少妇高潮99精品| 日本成人在线播放网站| 国产三级精品在线免费| 国产男女免费完整视频| 久久综激情丁香开心婷婷|