日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 前端技术 > vue >内容正文

vue

vuex 实现vue中多个组件之间数据同步以及数据共享。

發(fā)布時(shí)間:2024/4/17 vue 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vuex 实现vue中多个组件之间数据同步以及数据共享。 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

http://pan.baidu.com/s/1hrJfpli ?demo下載地址

前言

  在一些項(xiàng)目中有很多數(shù)據(jù)狀態(tài)之間要實(shí)現(xiàn)數(shù)據(jù)共享狀態(tài)共享,例如購(gòu)物車的數(shù)據(jù)、用戶的登錄狀態(tài)等等。vue父元素是可以通過props向子元素傳遞參數(shù),子元素也可以通用smit向父元素傳遞參數(shù)。但是像購(gòu)物車這種在項(xiàng)目中多個(gè)位置的引用時(shí)就會(huì)變得很麻煩。例如項(xiàng)目中使用了三個(gè)購(gòu)物車的組件,那么當(dāng)其中一個(gè)組件的值發(fā)生改變時(shí),就要通過自身告訴父組件我的值發(fā)生改變了,然后父組件在通知其他兩個(gè)購(gòu)物車組件值發(fā)生改變了,需要進(jìn)行同步,這樣就會(huì)變得很麻煩。而vue-v就可以幫助我們解決這個(gè)繁瑣的問題。

npm安裝

  npm install vuex?

開始使用

  項(xiàng)目需求:實(shí)現(xiàn)購(gòu)物車商品增加和減少,并計(jì)算出商品的總價(jià)。

  目錄結(jié)構(gòu)

?

  準(zhǔn)備工作

  第一步要引入在main.js中引入 vuex

import Vuex from 'vuex'

  第二步注冊(cè)vuex組件

Vue.use(Vuex)

  第三步實(shí)例化Store

  state:保存的是原始數(shù)據(jù),可以理解為需要共享的數(shù)據(jù)或狀態(tài),

  getters:可以理解為是staore的計(jì)算屬性,可以實(shí)現(xiàn)就store的計(jì)算,但是不能更改。例如你想知道兩個(gè)值相加、相乘。都是非常不錯(cuò)的選擇。

  mutations:mutations中的方法可以對(duì)state中的數(shù)據(jù)進(jìn)行改變。

  action:action中的方法可以調(diào)用mutations中的方法,但不可修改state中的原始數(shù)據(jù)。action中的函數(shù)可以使用ajax的技術(shù)對(duì)服務(wù)器進(jìn)行數(shù)據(jù)交互。并且可以在回調(diào)中使用commit調(diào)用mutations中的方法,例如通過context.commit('increment', price)increment是需要調(diào)用mutations中的方法名,price是需要傳入的參數(shù)。 mutations中的方法再去更改state的原始數(shù)據(jù)。

?  代碼示例

let store = new Vuex.Store({state: {totalPrice: 0},getters: {getTotal (state) {return state.totalPrice*2}},mutations: {increment (state, price) {state.totalPrice += price},decrement (state, price) {state.totalPrice -= price}},actions: {increase (context, price) {context.commit('increment', price)}} })

  如何在組件中獲得state數(shù)據(jù)?

  在組件內(nèi)部使用 this.$store.state.屬性名即可。

  實(shí)例代碼:

  computed: {totalPrice () {return this.$store.state.totalPrice}

  如何在組件中使用getters內(nèi)的方法?

computed: {getTotal () {return this.$store.getters.getTotal} }

  

?

  如何在組件中使用mutations內(nèi)的方法?

methods: {addOne () {this.$store.commit('increment', this.price)},minusOne () {this.$store.commit('decrement', this.price)}}

  如何在組件中使用actions內(nèi)的方法?

methods: {addOne () {this.$store.dispatch('increase', this.price)}}

  

?

轉(zhuǎn)載于:https://www.cnblogs.com/waitforyou/p/6784838.html

總結(jié)

以上是生活随笔為你收集整理的vuex 实现vue中多个组件之间数据同步以及数据共享。的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。