国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

vuex實現購物車邏輯

阿羅 / 3292人閱讀

摘要:當需要引入多個狀態和事件時不需要一個一個的引入,集體引入很方便使用的時候要先引入這些變量值都屬于計算屬性,在文件中寫在里面屬于事件實戰實戰是最重要的,容易發現問題,可以進步飛快用完成的有關購物車部分的小項目歡迎

前言

在小型項目中,組件與組件之間通信比較簡單。父組件可以使用pros向子組件傳遞數據,子組件可以通過$emit向父組件傳遞事件和數據,一旦狀態管理多了,代碼就會變得十分混亂。由于狀態零散的分布在許多組件和組件之間的交互中,大型應用復雜度也經常逐漸增長。vuex狀態管理庫可以很方便的統一管理項目的狀態,無論是對現在的開發人員還是將來新接手的開發人員都容易管理和維護。并且,一些邏輯代碼也可以抽離出來,具體哪里需要用到只需要分發一下事件,簡單方便。

Vuex組成

Vuex由以下部分組成:

state 存放項目中各種多組件共享的狀態

mutations 存放更改state里狀態的方法

getters 從state里派生出來的狀態,,比如將state中的某種狀態進行過濾然后獲取到的新的狀態

actions 通過commit mutations中的方法來改變狀態,可以進行異步操作

modules將狀態按模塊劃分,將Store對象分割成多個子模塊,使代碼結構更加清晰

通用配置
import * as types from "../types.js"
const state = {}
const actions = {}
const mutations = {}
const getters = {}
export default {
    state,
    actions,
    mutations,
    getters
}

若是有多個模塊:

|__store
    |__moduleName1
    |__moduleName2
        |__state.js
        |__types.js
        |__actions.js
        |__mutations.js
        |__index.js
        |__getters.js
    |__index.js

index.js文件中導出模塊

import Vue from "vue"
import Vuex from "vuex"
Vue.use(Vuex)

import moduleName1 from "./moduleName1"
import moduleName2 from "./moduleName2"


export detault new Vuex.Store({
    modules: {
        moduleName1,
        moduleName2,
    }
})

注意點:
所有子模塊的getters對象里的方法會被合并到$store里,如果不同的子模塊有重名的方法,就會報錯,只要在index.js文件上導出模塊的地方加上namespace:true就可以了。

mapGetters,mapActions,mapState

當需要引入多個狀態和事件時不需要一個一個的引入,集體引入很方便
使用的時候要先引入這些變量

import {mapGetters, mapActions, mapState} from "vuex"

mapGetters,mapState值都屬于計算屬性,在文件中寫在computed里面

computed: {
    ...mapGetters({
        ......
    }),
    ...mapState({
        ......
    }),
    otherCompuedValue() {......}
}

mapActions屬于事件

methods: {
    ...mapActions({
        ......
    })
}
實戰

實戰是最重要的,容易發現問題,可以進步飛快~
用vuex完成的有關購物車部分的小項目:https://github.com/Gcalolin/v...

歡迎star~

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/93694.html

相關文章

  • vue2 + vuex 高度還原 餓了么 App,與官方后臺真實數據交互,獲取商品信息,實現登陸、購

    摘要:注此項目純屬個人瞎搞,正常下單請選擇餓了么官方客戶端。目前下單功能已經實現,下單功能完全采用官網真實數據,可以控制官網發短信或者打電話到指定的手機號碼,下單后可以在手機中查看并且付款。 前言 vue2的發布后自己也研究了一段時間,奈何公司的技術棧是以react為主,沒有機會好好利用vue2去做一個完整的項目。雖然寫了幾個demo,但和寫一個完整的項目還是有很大差別的。于是自己想著用空余...

    JeOam 評論0 收藏0
  • 瞎說vuex

    摘要:本來說好寫完組件通信后就會寫相關的東西,現在快過去兩個多月了,主要是由于自己工作的原因,后面會保證更新速度的。它采用集中式存儲管理應用的所有組件的狀態,并以相應的規則保證狀態以一種可預測的方式發生變化。改變中的狀態的唯一途徑就是顯式地提交。 本來說好寫完組件通信后就會寫vuex相關的東西,現在快過去兩個多月了,主要是由于自己工作的原因,后面會保證更新速度的。不廢話了,直接正題。個人博客...

    OBKoro1 評論0 收藏0
  • Vue全家桶商城全站升級之引入HTTPS,PWA,錯誤監控,持續構建。

    摘要:免費升級到升級到后,服務器可以開啟版本,對比性能和緩存各方面要更好,還有其他新特性,可以啟動功能,更好的進行離線緩存,更好的離線體驗。 showImg(https://segmentfault.com/img/remote/1460000012773891?w=370&h=661); 在線地址:https://fancy.czero.cn 手機掃描二維碼查看: showImg(http...

    zengdongbao 評論0 收藏0
  • [vue][plugin][vuex][自總結] - vuex-總結

    摘要:原文出自本人博客的詳細總結博主博客兼乎說在前面最近在使用做項目,所以有了總結的念頭。在這種情況下,只有當所有觸發函數完成后,返回的才會執行。當模塊被注冊后,它的所有及都會自動根據模塊注冊的路徑調整命名。 原文出自本人博客:vuex的詳細總結博主博客--兼乎 說在前面 最近在使用vuex做項目,所以有了總結vuex的念頭。于是在本天中午到晚上9點,我一直沒有停過,為了能盡快將vuex的重...

    dackel 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<