欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vuex數(shù)據(jù)的存儲與獲取方式

 更新時間:2022年06月24日 15:41:32   作者:Vc編碼中  
這篇文章主要介紹了Vuex數(shù)據(jù)的存儲與獲取方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Vuex數(shù)據(jù)存儲與獲取

因為最近需要對原有項目進行改造,之前沒有認真研究過vuex的使用,今天把學習官方文檔的過程記錄下來以供日后查閱,同時也希望能夠為其他開發(fā)人員提供參考。

vuex的核心點是store,store本質上是一個倉庫,它可以存儲大部分的state。而這種存儲是響應式的,如果state發(fā)生變化,那么對應的組件也會響應更新。如果想要改變state,那么需要通過commit mutation。

以下示例引用自官網(wǎng)(開始 | Vuex)

// 創(chuàng)建一個新的 store 實例
const store = createStore({
? state () {
? ? return {
? ? ? count: 0
? ? }
? },
? mutations: {
? ? increment (state) {
? ? ? state.count++
? ? }
? }
})

創(chuàng)建完成后可在vue組件中可以以this.$store.commit('具體mutation方法')來提交狀態(tài)變更

然后通過this.$store.state.x具體某一statex來得到對象的內容。

如果想要更簡便的從store實例中讀取狀態(tài),可以直接在computed中返回某個狀態(tài):

// 創(chuàng)建一個 Counter 組件
const Counter = {
? template: `<div>{{ count }}</div>`,
? computed: {
? ? count () {
? ? ? return store.state.count
? ? }
? }
}

但是為了避免多次出發(fā)dom,vue插件可以將store實例從跟組件中注入到所有的子組件中,子組件可以通過$store訪問。

const Counter = {
? template: `<div>{{ count }}</div>`,
? computed: {
? ? count () {
? ? ? return this.$store.state.count
? ? }
? }
}

當我們需要的狀態(tài)為多個時,可以利用mapState來生成計算屬性

computed: {
? localComputed () { /* ... */ },
? // 使用對象展開運算符將此對象混入到外部對象中
? ...mapState({
? ? // ...
? })
}

可以舉一個實際應用的例子

首先在main.js中注冊

import Vuex from 'vuex'?
Vue.use(Vuex)
?
const store = new Vuex.Store({
//存放全局狀態(tài)
state:{
count:0
},
?
//getters是對state的加工包裝,比如將一些數(shù)據(jù)進行過濾等,為只讀的方法,通過return獲取值
getters:{
countNum(state){
return `the account NUm is ${state.count}`
}
}
?
//通過mutations修改state,如果直接修改state會導致一些特性丟失
mutations:{
?add(state){
state.count++
},
?minus(state){
state.count--
}??
}??
//actions涉及業(yè)務邏輯,不涉及頁面的一些行為?
})

在對應的vue組件中,如下代碼可在頁面顯示count的值,則可在vue的一個組件例如app.vue中進行如下操作

<template>
?
<div>
<h1>{{count}}</h1>
<h2>{{countNum}} </h2>
</div>
?
</template>
<script>?
import {mapState,mapGetters} from 'vuex'?
export default{
?
//
computed:{
...mapState(['count'])
...mapGetters{['countNum']}
}
}
</script>

若想使用mutation中的方法,則可在另一個vue文件例如hello.vue中進行如下操作,同時為了方便觀察,在控制臺中可以選擇vuex實時觀察vue內容

<template>
<div>
<button @click=addnum>增加</button>
</div>
</template>

  

methods:{
...mapMutations('add','minus')
addnum(){
//mutations必須通過commit才能使用,但是因為之前調用了...mapMutations,所以可以直接調用this.add();
//this.$store.commit('add')
this.add()
?
//使用mutations會確保有vuex狀態(tài)改變的記錄,如果直接this.$store.state.count也會生效
//this.$store.state.count++但是此種寫法開發(fā)工具vuex里面無法產生記錄
}
}
?
<javascript>
</javascript>

一般情況下,簡單的業(yè)務邏輯要寫在mutation里,復雜的業(yè)務邏輯要寫在actions里 

Vuex存值與取值(簡單易懂)

組件內存值

methods: { ?
? ? ?fn() { ? ??
? ? ? ? ? ? ?this.$store.commit('setValue',xxx) ? //setValue存值隨便起個名, ? xxx要存的值?
? ? ? ? ? } ? ? ? ? ??
? ? }

store.js的state中

const state = {
? ? xxx:'',//把存的那個值的名字初始化一下
}

store.js的matution中

? setValue(state,item){
? ? state.xxx= item;//第二個參數(shù)隨意起個名
? },

組件內取值

//在計算屬性中取值,js直接這樣寫拿到值,html用直接xxx使用
?computed: { ? ?
? ? value() {
? ? ? return this.$store.state.xxx;
? ? }
? },

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 詳解Vue之父子組件傳值

    詳解Vue之父子組件傳值

    這篇文章主要介紹了Vue之父子組件傳值,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • Vue實現(xiàn)預覽文件(Word/Excel/PDF)功能的示例代碼

    Vue實現(xiàn)預覽文件(Word/Excel/PDF)功能的示例代碼

    這篇文章主要為大家詳細介紹了如何通過Vue實現(xiàn)預覽文件(Word/Excel/PDF)的功能,文中的實現(xiàn)步驟講解詳細,需要的小伙伴可以參考一下
    2023-03-03
  • vue-element-admin?登陸及目錄權限控制的實現(xiàn)

    vue-element-admin?登陸及目錄權限控制的實現(xiàn)

    本文主要介紹了vue-element-admin?登陸及目錄權限控制的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-04-04
  • Element-UI表格嵌入popover遇到的問題及解決方案

    Element-UI表格嵌入popover遇到的問題及解決方案

    在表格中我們通常需要在每一行的一些單元格中顯示popover,這篇文章主要給大家介紹了關于Element-UI表格嵌入popover遇到的問題及解決方案,需要的朋友可以參考下
    2023-11-11
  • Vue進階之CodeMirror的應用小結

    Vue進階之CodeMirror的應用小結

    CodeMirror支持在線編輯代碼,風格包括js, java, php, c++等等100多種語言,下面這篇文章主要來和大家講講CodeMirror的應用,感興趣的可以了解一下
    2023-06-06
  • 使用Vue-Router 2實現(xiàn)路由功能實例詳解

    使用Vue-Router 2實現(xiàn)路由功能實例詳解

    vue-router 2只適用于Vue2.x版本,下面我們是基于vue2.0講的如何使用vue-router 2實現(xiàn)路由功能,需要的朋友可以參考下
    2017-11-11
  • vue中怎樣讓函數(shù)只執(zhí)行一次

    vue中怎樣讓函數(shù)只執(zhí)行一次

    這篇文章主要介紹了vue中怎樣讓函數(shù)只執(zhí)行一次問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • vue高德地圖之玩轉周邊

    vue高德地圖之玩轉周邊

    vue高德地圖,帶你玩轉周邊,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • vue同步父子組件和異步父子組件的生命周期順序問題

    vue同步父子組件和異步父子組件的生命周期順序問題

    這篇文章主要介紹了vue同步父子組件和異步父子組件的生命周期順序問題,需要的朋友可以參考下
    2018-10-10
  • vue3?vscode插件volar配置教程

    vue3?vscode插件volar配置教程

    這篇文章主要介紹了vue3?vscode插件volar配置,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07

最新評論