這篇文章主要介紹了vuex 專案結構目錄及一些簡單配置,需要的朋友可以參考下
首先先正經的來一段官網的"忠告":
vuex需要遵守的規則:
一、應用層級的狀態應該集中到單一store 物件。
二、提交 mutation 是更改狀態的唯一方法,而這個過程是同步的。
三、非同步邏輯都應該封裝到 action 裡面。
檔案目錄結構
檔案之間的關係:
store資料夾- 存放vuex的系列檔案
store.js - 引入vuex,設定state狀態數據,引入getter、mutation和action
getter.js - 取得store內的狀態
mutation.js - 更改store中狀態用的函數的儲存之地
action.js - 提交mutation以達到委婉地修改state狀態,可非同步操作
簡單而又普通的寫法
store.js文件:
import Vue from 'vue' import Vuex from 'vuex' import actions from './actions' import mutations from './mutations' Vue.use(Vuex) const state = { a: '初始值', b: 'balabala...' } export default new Vuex.Store({ state, actions, mutations })
main.js檔案中(從根元件注入store,就像注入router一樣):
透過在根實例中註冊store 選項,此store 實例會注入到根元件下的所有子元件中,且子元件能透過this.$store 存取。
import store from './store/index' new Vue({ el: '#app', router, store, ... })
Getter.js 的簡單設定( store 的計算屬性,接受state為參數)
export default { doneTodos: state = >{ return state.todos.filter(todo = >todo.done) } }
#取得(某元件的計算屬性內部):
computed: { doneTodosCount () { return this.$store.getters.doneTodosCount } }
可傳參的getter屬性的簡單設定
export default{ getTodoById: (state) => (id) => { return state.todos.find(todo => todo.id === id) } }
取得(某元件的計算屬性內部):
#computed: { getTodoById() { return this.$store.getters.getTodoById(‘参数') } }
mutation.js簡單設定:
export default { increment(state) { //变更状态 state.count++ } }
觸發(元件中)
#this.$store.commit(state,payload) actions.js简单配置: export default{ action (context) { //异步操作 setTimeout(()=>{ //变更状态 context.commit('mutationFunName',value) }) } }
觸發(元件的)
this.$store.dispatch('mutationFunctionName') 2018-04-07 18:13:34
上面是我整理給大家的,希望今後對大家有幫助。
相關文章:
#
以上是vuex 專案結構目錄及一些簡單設定介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

linux查看目录是否为空的方法:1、进入linux终端;2、通过执行“res=`ls -A $dir` if [ -z $res ];then echo "$dir ..."else echo "$dir ..."fi”方法判断目录是否为空即可。
![在Vue应用中使用vuex时出现“Error: [vuex] do not mutate vuex store state outside mutation handlers.”怎么解决?](https://img.php.cn/upload/article/000/000/164/168760467048976.jpg)
在Vue应用中,使用vuex是常见的状态管理方式。然而,在使用vuex时,我们有时可能会遇到这样的错误提示:“Error:[vuex]donotmutatevuexstorestateoutsidemutationhandlers.”这个错误提示是什么意思呢?为什么会出现这个错误提示?如何解决这个错误?本文将详细介绍这个问题。错误提示的含

Vuex是做什么的?Vue官方:状态管理工具状态管理是什么?需要在多个组件中共享的状态、且是响应式的、一个变,全都改变。例如一些全局要用的的状态信息:用户登录状态、用户名称、地理位置信息、购物车中商品、等等这时候我们就需要这么一个工具来进行全局的状态管理,Vuex就是这样的一个工具。单页面的状态管理View–>Actions—>State视图层(view)触发操作(action)更改状态(state)响应回视图层(view)vuex(Vue3.

Vue2.x是目前最流行的前端框架之一,它提供了Vuex作为管理全局状态的解决方案。使用Vuex能够使得状态管理更加清晰、易于维护,下面将介绍Vuex的最佳实践,帮助开发者更好地使用Vuex以及提高代码质量。1.使用模块化组织状态Vuex使用单一状态树管理应用的全部状态,将状态从组件中抽离出来,使得状态管理更加清晰易懂。在具有较多状态的应用中,必须使用模块
![在Vue应用中使用vuex时出现“Error: [vuex] unknown action type: xxx”怎么解决?](https://img.php.cn/upload/article/000/887/227/168766615217161.jpg)
在Vue.js项目中,vuex是一个非常有用的状态管理工具。它可以帮助我们在多个组件之间共享状态,并提供了一种可靠的方式来管理状态的变化。但在使用vuex时,有时会遇到“Error:[vuex]unknownactiontype:xxx”的错误。这篇文章将介绍该错误的原因及解决方法。1.错误原因在使用vuex时,我们需要定义一些actions和mu

在Vue应用中使用Vuex是非常常见的操作。然而,偶尔在使用Vuex时会遇到错误信息“TypeError:Cannotreadproperty'xxx'ofundefined”,这个错误信息的意思是无法读取undefined的属性“xxx”,导致了程序的错误。这个问题其实产生的原因很明显,就是因为在调用Vuex的某个属性的时候,这个属性没有被正确

linux查看目录占用空间大小的方法:1、使用“du -h --max-depth=0”命令查看当前目录使用的总空间大小;2、使用“du -h --max-depth=1”命令查看当前目录下某文件使用空间大小。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 Linux新版
SublimeText3 Linux最新版

SublimeText3漢化版
中文版,非常好用

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)