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

vue3使用Pinia修改state的三種方法(直接修改,$patch,actions)

 更新時(shí)間:2024年03月13日 09:56:45   作者:Jay丶蕭邦  
Vue3?Pinia是一個(gè)狀態(tài)管理庫(kù),專門為Vue3設(shè)計(jì)優(yōu)化,它提供了一種簡(jiǎn)單而強(qiáng)大的方式來(lái)管理應(yīng)用程序的狀態(tài),并且與Vue3的響應(yīng)式系統(tǒng)緊密集成,本文給大家介紹了vue3使用Pinia修改state的三種方法,需要的朋友可以參考下

本篇記錄vue3 使用pinia修改state的三種方法

1. 新建vue3項(xiàng)目,安裝Pinia(參考鏈接:Vue狀態(tài)管理工具Pinia的安裝與使用教程_vue.js_腳本之家 (jb51.net))

2.目錄

app.js

import {defineStore} from "pinia"
 
const appStore = defineStore('appStore', {
    state: () => ({
        baseUrl: 'https://www.baidu.com/',
        ipList: ['192.168.10.777', '192.168.10.999', '192.168.10.888']
    }),
    actions: {
        changeState(params) {
            console.log('接收到的參數(shù)===>', params)
            this.baseUrl = params
            this.ipList.push('192.168.10.100')
        }
    }
})
 
export default appStore

第一種修改方式:直接state = '數(shù)據(jù)'  ,不推薦

    const store = appStore()
    let {baseUrl, ipList} = storeToRefs(store)
 
    /*
    *  第一種修改方式:雖然可以直接修改,但是出于代碼結(jié)構(gòu)來(lái)說(shuō),
    *               全局的狀態(tài)管理還是不要直接在各個(gè)組件處隨意修改狀態(tài),
    *               應(yīng)放于 action 中統(tǒng)一方法修改(piain沒有mutation)
    *               并不推薦?。?!
    * */
    function changeData() {
      // baseUrl = 'https://www.taobao.com/'  //error 這么寫是沒有用的
      store.baseUrl = 'https://www.taobao.com/'  //success
      store.ipList.push('192.168.10.111')  //success
    }

第二種修改方式:使用$patch修改數(shù)據(jù)

    const store = appStore()
    // 第二種修改方式:使用$patch改變數(shù)據(jù) $patch 可以同時(shí)修改多個(gè)值
    function changeDataByPatch() {
      /*
      $patch也有兩種的調(diào)用方式
      第一種寫法的在修改數(shù)組時(shí),假如我只想要把 ipList 的中第2項(xiàng)改成‘192.168.10.222',
      但是也需要傳入整個(gè)包括所有元素的數(shù)組,這無(wú)疑增加了書寫成本和風(fēng)險(xiǎn),顯然是不合理的,所以一般都推薦使用第二種傳入一個(gè)函數(shù)的寫法
      * */
      // 第一種 $patch方法
      // store.$patch({
      //   baseUrl: 'https://www.jd.com/',
      //   ipList: ['192.168.10.777', '192.168.10.222', '192.168.10.888']
      // })
 
      // 第二種 $patch方法
      store.$patch((state) => {
        state.baseUrl = 'https://www.jd.com/'
        state.ipList[0] = '192.168.10.222'
      })
    }

第三種修改方式:使用actions中的方法修改數(shù)據(jù) (推薦)

    // 第三種修改方式:調(diào)用store中的action改變數(shù)據(jù)
    function changeDataByAction() {
      store.changeState('https://www.alibabagroup.com/cn/global/home')  //可以直接給actions里面的方法傳遞參數(shù)
    }

以上就是使用pinia修改數(shù)據(jù)的三種方法

pinia重置數(shù)據(jù)的功能,這個(gè)操作很簡(jiǎn)單

    const store = appStore()
    // 重置數(shù)據(jù)
    function resetData() {
      store.$reset()
    }

完整代碼:

<template>
  <div>
    <strong>baseUrl:</strong>
    {{ baseUrl }}
  </div>
  <div>
    <strong>ipList:</strong>
    {{ ipList }}
  </div>
  <div>
    <button @click="changeData">直接在頁(yè)面組件中改變數(shù)據(jù)</button>
    <button @click="changeDataByPatch">使用$patch改變數(shù)據(jù)</button>
    <button @click="changeDataByAction">使用action改變數(shù)據(jù)</button>
    <button @click="resetData">重置數(shù)據(jù)</button>
  </div>
</template>
 
<script>
import appStore from "@/store/app"
import {storeToRefs} from "pinia"
 
export default {
  name: "Home",
  setup() {
    const store = appStore()
    let {baseUrl, ipList} = storeToRefs(store)
 
    /*
    *  第一種修改方式:雖然可以直接修改,但是出于代碼結(jié)構(gòu)來(lái)說(shuō),
    *               全局的狀態(tài)管理還是不要直接在各個(gè)組件處隨意修改狀態(tài),
    *               應(yīng)放于 action 中統(tǒng)一方法修改(piain沒有mutation)
    *               并不推薦?。?!
    * */
    function changeData() {
      // baseUrl = 'https://www.taobao.com/'  //error 這么寫是沒有用的
      store.baseUrl = 'https://www.taobao.com/'  //success
      store.ipList.push('192.168.10.111')  //success
    }
 
    // 第二種修改方式:使用$patch改變數(shù)據(jù) $patch 可以同時(shí)修改多個(gè)值
    function changeDataByPatch() {
      /*
      $patch也有兩種的調(diào)用方式
      第一種寫法的在修改數(shù)組時(shí),假如我只想要把 ipList 的中第2項(xiàng)改成‘192.168.10.222',
      但是也需要傳入整個(gè)包括所有元素的數(shù)組,這無(wú)疑增加了書寫成本和風(fēng)險(xiǎn),顯然是不合理的,所以一般都推薦使用第二種傳入一個(gè)函數(shù)的寫法
      * */
      // 第一種 $patch方法
      // store.$patch({
      //   baseUrl: 'https://www.jd.com/',
      //   ipList: ['192.168.10.777', '192.168.10.222', '192.168.10.888']
      // })
 
      // 第二種 $patch方法
      store.$patch((state) => {
        state.baseUrl = 'https://www.jd.com/'
        state.ipList[0] = '192.168.10.222'
      })
    }
 
    // 第三種修改方式:調(diào)用store中的action改變數(shù)據(jù)
    function changeDataByAction() {
      store.changeState('https://www.alibabagroup.com/cn/global/home')  //可以直接給actions里面的方法傳遞參數(shù)
    }
 
    // 重置數(shù)據(jù)
    function resetData() {
      store.$reset()
    }
 
    return {
      baseUrl,
      ipList,
      changeData,
      changeDataByPatch,
      changeDataByAction,
      resetData
    }
  }
}
</script>

以上就是vue3使用Pinia修改state的三種方法(直接修改,$patch,actions)的詳細(xì)內(nèi)容,更多關(guān)于vue3 Pinia修改state的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue使用mui遇到的坑及解決

    vue使用mui遇到的坑及解決

    這篇文章主要介紹了vue使用mui遇到的坑及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Vue中的?ref,props,mixin屬性

    Vue中的?ref,props,mixin屬性

    這篇文章主要介紹了Vue中的ref,props,mixin屬性,文章圍繞主題ref,props,mixin展開詳細(xì)內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-05-05
  • 如何用 Deepseek 寫的uniapp血型遺傳查詢工具

    如何用 Deepseek 寫的uniapp血型遺傳查詢工具

    在現(xiàn)代社會(huì)中,了解血型遺傳規(guī)律對(duì)于優(yōu)生優(yōu)育、醫(yī)療健康等方面都有重要意義,本文將介紹如何使用Uniapp開發(fā)一個(gè)跨平臺(tái)的血型遺傳查詢工具,幫助用戶預(yù)測(cè)孩子可能的血型,感興趣的朋友一起看看吧
    2025-04-04
  • Vue路由組件傳遞參數(shù)的六種場(chǎng)景

    Vue路由組件傳遞參數(shù)的六種場(chǎng)景

    在Vue應(yīng)用程序中,路由組件是構(gòu)建單頁(yè)應(yīng)用的關(guān)鍵部分,傳遞參數(shù)給路由組件可以讓我們動(dòng)態(tài)地展示內(nèi)容,處理用戶輸入,以及實(shí)現(xiàn)各種交互功能,本文就給大家介紹了六種Vue路由組件傳遞參數(shù)場(chǎng)景,需要的朋友可以參考下
    2023-09-09
  • 在Vue當(dāng)中同時(shí)配置多個(gè)路由文件的方法案例代碼

    在Vue當(dāng)中同時(shí)配置多個(gè)路由文件的方法案例代碼

    這篇文章主要介紹了在Vue當(dāng)中同時(shí)配置多個(gè)路由文件的方法,包含具體代碼,本文分步驟結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-12-12
  • elementui el-table中如何給表頭 el-table-column 加一個(gè)鼠標(biāo)移入提示說(shuō)明

    elementui el-table中如何給表頭 el-table-column 加一個(gè)鼠

    本文通過(guò)實(shí)例代碼介紹如何在使用Element UI的el-table組件時(shí)為表頭添加提示功能,通過(guò)結(jié)合el-tooltip組件實(shí)現(xiàn)鼠標(biāo)移入時(shí)顯示提示信息,感興趣的朋友跟隨小編一起看看吧
    2024-11-11
  • 使用Webpack提升Vue.js應(yīng)用程序的4種方法(翻譯)

    使用Webpack提升Vue.js應(yīng)用程序的4種方法(翻譯)

    這篇文章主要介紹了使用Webpack提升Vue.js應(yīng)用程序的4種方法(翻譯),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Vue3格式化Volar報(bào)錯(cuò)的原因分析與解決

    Vue3格式化Volar報(bào)錯(cuò)的原因分析與解決

    Volar 與vetur相同,volar是一個(gè)針對(duì)vue的vscode插件,下面這篇文章主要給大家介紹了關(guān)于Vue3格式化Volar報(bào)錯(cuò)的原因分析與解決方法,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • vue實(shí)現(xiàn)登錄數(shù)據(jù)的持久化的使用示例

    vue實(shí)現(xiàn)登錄數(shù)據(jù)的持久化的使用示例

    在Vue.js中,實(shí)現(xiàn)登錄數(shù)據(jù)的持久化需要使用瀏覽器提供的本地存儲(chǔ)功能,Vue.js支持使用localStorage和sessionStorage來(lái)實(shí)現(xiàn)本地存儲(chǔ),本文就來(lái)介紹一下如何實(shí)現(xiàn),感興趣的可以了解一下
    2023-10-10
  • vue 計(jì)時(shí)器組件的實(shí)現(xiàn)代碼

    vue 計(jì)時(shí)器組件的實(shí)現(xiàn)代碼

    本篇文章主要介紹了vue 計(jì)時(shí)器組件的實(shí)現(xiàn)代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09

最新評(píng)論