轻松搞定Vue3+Pinia-4-多个store

1. 前言

  1. Vue3大势不可阻挡,与之而来的就是Vite ,尤雨溪极力推荐的前端开发构建工具
  2. vue3原生支持TS ,所以TS语法vue3TS语法学起来
  3. vue中的vuex状态管理也用不顺手,看不顺眼了,换为Pinia
  4. 文接上篇 Vue3+Pinia-3-getters
  5. 之前一套流程pinia共享state,访问,修改算是基础的使用了,接下里说下不太常用的东西

2. 新建一个store

  1. 新建 src/store/carStore.ts,模拟多个store的场景
  2. 操作都一样,直接上代码
import {defineStore} from 'pinia'
export const carStore = defineStore('carStoreId',{
    // 这种写法 有道友反馈看起来 还是需要反应下 😓😓
    // state:()=>({})
    state:()=>{
        return{
            carList:['唐-DMI','汉EV-千山翠','海豹','领跑C01']
        }
    }
})

3. 组件 使用 carStore

  1. 没有套路,就直接使用
  2. src/components/HelloCar.vue
  3. 在App.vue中引入组件显示 看效果
<template>
    <div>
        <h1> 多个store</h1>
        <h1>{{ store.carList }}</h1>
        <hr>
        <h1>{{carList}}</h1>
    </div>
</template>

<script setup lang="ts">
import { carStore } from '../store/carStore'
import { storeToRefs } from 'pinia'

let store = carStore()
let { carList} = storeToRefs(store)

</script>

<style scoped>
</style>
  1. 效果图
    1.png
  2. 组合式API,像组装积木一样,功能分割,需要啥组到一起就行
  3. 调试多个store
    调试.png

4. store互相调用

4.1 场景分析

  1. 一个store想使用另外一个store内的数据咋办呢
  2. 拿上述的这个 carStorehelloStore为例
  3. 需求:helloStore使用 carStore里面的数据carList

4.2 helloStore配置

  1. 整体思路是 在actions中定义函数,函数中访问其他store数据
  2. 引入 import {carStore} from './carStore'
  3. actions 配置 函数/getCarList
  4. 函数内部用carStore()访问carStore自己的数据
import {carStore} from './carStore'
export const helloStore = defineStore("hello", {
    // 必须用箭头函数
    state: () => ({
        name:'温言铁语',
        age: 71,
        phone:"18603038753",//手机号中间四位 *代替 脱敏处理
    }),
    actions:{
        updateState(){
            this.age ++
            this.name = 'yzs'
        },
        getCarList(){
            console.log("-------carStore",carStore().carList);
        }
    },
    getters:{
        starPhone(state){
            console.log("缓存---值一样不会被多次调用");
            return state.phone.toString().replace(/^(\d{3})\d{4}(\d{4})$/ ,'$1****$2')
        }
    }
});

5. 组件内使用

  1. 添加一个获取按钮
        <hr>
        <button @click=" getList">获取carStore数据 </button>
  1. 事件实现逻辑
const store = helloStore()
const getList = ()=>{
    store.getCarList()
 //  可以赋值给当前界面的数据
}
  1. 查看控制台打印,证明调用并获取到了 carStore的数据

6. 后记

  1. 推荐下载插件的地址
  2. Volar比vetur更强大的 vscode插件,提供了更好的vue3语法支持
  3. 全名Vue Language Features (Volar) 骷髅头/☠️,向着 one piece出发吧

参考资料

Vite
Pinia
轻松搞定 Vue3+Vite+Pinia-1-state
轻松搞定 Vue3+Vite+Pinia-2-state-修改
轻松搞定 Vue3+Vite+Pinia-3-getters


初心

我所有的文章都只是基于入门,初步的了解;是自己的知识体系梳理,如有错误,道友们一起沟通交流;
如果能帮助到有缘人,非常的荣幸,一切为了部落的崛起;
共勉
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容