vue3中Pinia

一、pinia的简单使用

vuex和pinia的区别

参考网址:[Vuex] Vuex 5 by kiaking · Pull Request #271 · vuejs/rfcs · GitHub

1.pinia没有mutations,只有:state、getters、actions

2.pinia分模块不需要models(之前vuex分模块需要models)

3.TS支持的很好

4.pinia体积更小(性能更好)

5.pinia可以直接修改state数据

 pinia的使用

1. npm i pinia

2. 在main.js中进行引用

        import { createPinia } from 'pinia';   

        export const app = createApp(App)

        app.use(createPinia());

3.在src下store文件下新建index.js

import { defineStore } from 'pinia'
const userStore = defineStore({
    id: 'useStore',//id必须唯一
    state: () => {
        return {
            token: '123',
            userInfo: null,
        }
    },
    getters:{

    },
    actions: {
        setToken(token) {
            this.token = token
        },
    },
})

export default userStore

4.在组件中使用pinia

        a.不结构state,通过pinia的actions去更改state

<template>
    <div class="A">
       <h1>A组件</h1> 
       <div>{{ store.token }}</div>
      <div>
        姓名:{{store.userInfo.name}} &nbsp;  年龄:{{ store.userInfo.age }}
      </div>
      <el-button  type="success" @click="changeName()">修改名称</el-button>
    </div>
</template>

<script setup>
import { userStore } from '../store/index.js';
const store = userStore()
let {setName} = store

let changeName =()=>{
    setName('李四')
}

</script>

<style lang="scss">
.A{
    font-size: 30px;
    margin: 0 auto;
    text-align: center;
    .el-button{
        font-size: 30px;
        padding: 10px;
        height: 50px;
    }
}
</style>

             

        b.结构state时候要使用storeToRefs去让它变成响应式数据从而改变

<template>
    <div class="A">
       <h1>A组件</h1> 
       <div>{{ token }}</div>
      <div>
        姓名:{{userInfo.name}} &nbsp;  年龄:{{ userInfo.age }}
      </div>
      <el-button  type="success" @click="changeName()">修改名称</el-button>
    </div>
</template>

<script setup>
import { storeToRefs } from 'pinia';
import { userStore } from '../store/index.js';
const store = userStore()
let {token,userInfo,setName} = storeToRefs(store)

let changeName =()=>{
    // userInfo.value.name='李四'
    //$patch批量修改
    store.$patch(state=>{
        console.log(state);
        state.userInfo.age=12
        state.userInfo.name='李四'
    })
}

</script>

<style lang="scss">
.A{
    font-size: 30px;
    margin: 0 auto;
    text-align: center;
    .el-button{
        font-size: 30px;
        padding: 10px;
        height: 50px;
    }
}
</style>

      

        c.pinia的getters

import { defineStore } from 'pinia'
export const userStore = defineStore({
    id: 'useStore',
    state: () => {
        return {
            token: 'gdsiuafoi1234_key',
            userInfo: {
                name:"张三",
                age:18
            },
        }
    },
    getters:{
        //箭头函数--接受参数
        getNameInfo:state=>{
            //箭头函数中this不是store
            return (param)=>`${state.userInfo.name}今年已经${state.userInfo.age}岁了${param}`
            
        },
        getNameInfo1(state){
            return function(param){
                return `2.${state.userInfo.name}今年已经${state.userInfo.age}岁了${param}`
            }
        }
    }
})
<template>
    <div class="A">
       <h1>A组件</h1> 
       <div>{{ token }}</div>
      <div>
        姓名:{{userInfo.name}} &nbsp;  年龄:{{ userInfo.age }}
      </div>
      <div>
        {{getNameInfo('是吗?')}}
      </div>
      <div>
        {{getNameInfo1(',对的')}}
      </div>
      <el-button  type="success" @click="changeName()">修改名称</el-button>
    </div>
</template>

<script setup>

import { storeToRefs } from 'pinia';
import { userStore } from '../store/index.js';
const store = userStore()
let {token,userInfo,setName,getNameInfo,getNameInfo1} = storeToRefs(store)

</script>

<style lang="scss">
.A{
    font-size: 30px;
    margin: 0 auto;
    text-align: center;
    .el-button{
        font-size: 30px;
        padding: 10px;
        height: 50px;
    }
}
</style>

二、pinia的分模块化

在store文件下通过不同的js进行分模块拆分

user.js

import { defineStore } from 'pinia'
export const user = defineStore({
    id: 'user',
    state: () => {
        return {
            token: 'gdsiuafoi1234_key',
            userInfo: {
                name:"张三",
                age:18
            },
        }
    },
    getters:{
        //箭头函数--接受参数
        getNameInfo:state=>{
            //箭头函数中this不是store
            return (param)=>`${state.userInfo.name}今年已经${state.userInfo.age}岁了${param}`
            
        },
        getNameInfo1(state){
            return function(param){
                return `2.${state.userInfo.name}今年已经${state.userInfo.age}岁了${param}`
            }
        }
    },
    actions: {
        setToken(token) {
            this.token = token
        },
        setName(name){
            this.userInfo.name=name
        }
    },
})

 shop.js

import { defineStore } from 'pinia'
export const shop = defineStore({
    id: 'shop',
    state: () => ({
      shopList:['鞋子','衣服'] 
    }),
    getters:{
       
    },
    actions: {
    
    },
})

使用:

<template>
    <div class="A">
       <h1>A组件</h1> 
        <div>
            {{userInfo.name}} &nbsp; {{userInfo.age}}
        </div>
        <div>
            {{getNameInfo('是吗?')}}
        </div>
        <el-button  type="success" @click="changeName()">修改名称</el-button>
        <div>
            shopStore
        </div>
        <div v-for="(el,index) in shopList" :key="index">
            {{el}}
        </div>
    </div>
</template>

<script setup>

import { storeToRefs } from 'pinia';
import { user } from '../store/user.js';
import {shop} from '../store/shop.js'
const userStore = user()
const shopStore = shop()
console.log(userStore);
let { userInfo,getNameInfo } = storeToRefs(userStore)
let { shopList } = storeToRefs(shopStore)

const changeName = ()=>{
    // userInfo.value.name='李四'
    userStore.setName('李四')
}

</script>

<style lang="scss">
.A{
    font-size: 30px;
    margin: 0 auto;
    text-align: center;
    .el-button{
        font-size: 30px;
        padding: 10px;
        height: 50px;
    }
}
</style>

          

 三、pinia的持久化存储

1.下载插件依赖:npm i pinia-plugin-persist -save

2.在store文件下新建index.js文件,再在main.js中引入并使用

        import store from './store/index.js';  app.use(store);

idnex.js

import { createPinia } from 'pinia'
//引入持久化插件
import piniaPluginPersist from 'pinia-plugin-persist'

const store = createPinia()
//使用插件
store.use(piniaPluginPersist)
export default store

在模块化中使用(user)

persist:{
        //是否启用持久化存储,不进行配置默认存储为session,刷新页面持久化了但是重新开启一个页面还是开始的值
        enabled:true
    }

a.基础使用

创建 Store 时,将 persist 选项设置为 true,整个 Store 将使用默认持久化配置保存。

默认持久化配置

        使用 session进行存储

        store.$id作为 storage 默认的 key

        使用 JSON.stringify / JSON.parse进行序列化/反序列化

        整个 state 默认将被持久发

b.高级使用

        三个常用属性:   

                key:存储名称。

                storage:存储方式。 sessionStorage 、localStorage

                path:用于指定 state 中哪些数据需要被持久化。[] 表示不持久化任何状态,undefined 或 null 表示持久化整个 state。

import { defineStore } from 'pinia'
export const user = defineStore({
    id: 'user',
    state: () => {
        return {
            token: 'gdsiuafoi1234_key',
            userInfo: {
                name:"张三",
                age:18
            },
        }
    },
    getters:{
        //箭头函数--接受参数
        getNameInfo:state=>{
            //箭头函数中this不是store
            return (param)=>`${state.userInfo.name}今年已经${state.userInfo.age}岁了${param}`
            
        },
        getNameInfo1(state){
            return function(param){
                return `2.${state.userInfo.name}今年已经${state.userInfo.age}岁了${param}`
            }
        }
    },
    actions: {
        setToken(token) {
            this.token = token
        },
        setName(name){
            this.userInfo.name=name
        }
    },
    persist:{
        //是否启用持久化存储,不进行配置默认存储为session,刷新页面持久化了但是重新开启一个页面还是开始的值
        enabled:true,
        strategies:[{
            key:'user_info',
            storage:localStorage,
            paths:['userInfo']
        }]
    }
})

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/384715.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

肿瘤微环境异质性对治疗反应的影响(综述)

Influence of tumour micro-environment heterogeneity on therapeutic response | Nature 肿瘤的形成涉及肿瘤细胞与细胞外基质、肿瘤血管和免疫细胞的共同进化。肿瘤的成功生长和最终转移并不完全取决于肿瘤细胞的基因改变&#xff0c;还取决于这种突变在特定环境中带来的适…

【Java程序设计】【C00270】基于Springboot的moba类游戏攻略分享平台(有论文)

基于Springboot的moba类游戏攻略分享平台&#xff08;有论文&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于Springboot的游戏攻略分享平台 本系统分为系统功能模块、管理员功能模块、以及用户后台功能模块。 系统功能模块&#xff1a;在平台首…

算法-3-基本的数据结构

单双链表 1.单链表双链表如何反转 import java.util.ArrayList; import java.util.List;public class Code01_ReverseList {public static class Node {public int value;public Node next;public Node(int data) {value data;}}public static class DoubleNode {public int…

ZigBee学习——BDB

✨本博客参考了善学坊的教程&#xff0c;并总结了在实现过程中遇到的问题。 善学坊官网 文章目录 一、BDB简介二、BDB Commissioning Modes2.1 Network Steering2.2 Network Formation2.3 Finding and Binding&#xff08;F & B&#xff09;2.4 Touchlink 三、BDB Commissi…

图像处理之《黑盒扰动的可逆噪声流鲁棒水印》论文阅读

一、文章摘要 近年来&#xff0c;基于深度学习的数字水印框架得到了广泛的研究。现有的方法大多采用基于“编码器-噪声层-解码器”的架构&#xff0c;其中嵌入和提取过程分别由编码器和解码器完成。然而&#xff0c;这种框架的一个潜在缺点是编码器和解码器可能不能很好地耦合…

linux系统下vscode portable版本的python环境搭建003:venv

这里写自定义目录标题 python安装方案一. 使用源码安装&#xff08;有[构建工具](https://blog.csdn.net/ResumeProject/article/details/136095629)的情况下&#xff09;方案二.使用系统包管理器 虚拟环境安装TESTCG 本文目的&#xff1a;希望在获得一个新的系统之后&#xff…

电路设计(15)——篮球赛24秒违例倒计时报警器的proteus仿真

1.设计要求 设计、制作一个篮球赛24秒违例倒计时报警器。要求&#xff1a; &#xff08;1&#xff09;具有倒计时功能。可完整实现从“24”秒开始依序倒计时并显示倒计时过程&#xff0c;显示时间间隔为1秒。 &#xff08;2&#xff09;具有消隐功能。当“24”秒倒计时…

洛谷: P1308 [NOIP2011 普及组] 统计单词数

前言: 这道题没理解清题目表达意思&#xff0c;我开始想的是用map来记录个数&#xff0c;然后一个变量记录一开始出现的单词位置&#xff0c;不挺简单的吗&#xff0c;然后....就AC了2个..从错误提示能看到个数没啥问题&#xff0c;但是第一个单词位置不对&#xff0c;看了新样…

【C语言】assert断言:保护程序的利器

在软件开发过程中&#xff0c;我们经常会遇到一些假设条件或者预期行为。例如&#xff0c;我们可能假设一个函数的输入参数必须在某个范围内&#xff0c;或者某个变量的值应该满足特定的条件。当这些假设或预期行为被打破时&#xff0c;程序可能会出现异常行为&#xff0c;甚至…

GEE:随机森林回归教程(样本点、特征添加、训练、精度、参数优化)

作者:CSDN @ _养乐多_ 对于分类问题,这个输出通常是一个类别标签 ,而对于回归问题,输出通常是一个连续的数值。回归可以应用于多种场景,包括预测土壤PH值、土壤有机碳、土壤水分、碳密度、生物量、气温、海冰厚度、不透水面积百分比、植被覆盖度等。 本文将介绍在Google…

嵌入式Qt Qt 中的坐标系统

一.Qt中的坐标系统 实验1&#xff1a;窗口坐标大小 #include <QtGui/QApplication> #include <QPushButton> #include <QDebug> #include "widget.h" int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();qDebug()&…

Vue中v-on 可以监听多个方法吗

当然可以&#xff01;Vue.js是一款非常强大的JavaScript库&#xff0c;它提供了很多方便的方法和指令&#xff0c;使我们可以更容易地构建交互式的Web应用程序。其中&#xff0c;v-on指令是Vue.js中一个非常重要也非常常用的指令&#xff0c;它用于监听DOM事件&#xff0c;并在…

【DDD】学习笔记-四色建模法

或许正是认识到彩色 UML 在建模过程的不足之处&#xff0c;ThoughtWorks 的徐昊才在彩色 UML 基础之上提出了自己的“四色建模法”。可考的四色建模法资料仅见于徐昊在 InfoQ 上发表的文章运用四色建模法进行领域分析。在这篇文章中&#xff0c;徐昊回答了建模活动的一个关键问…

网络渗透测试:Wireshark抓取qq图片

Wireshark Wireshark Downloadhttps://www.wireshark.org/download.html 简介 WireShark是非常流行的网络封包分析工具&#xff0c;可以截取各种网络数据包&#xff0c;并显示数据包详细信息。常用于开发测试过程中各种问题定位。本文主要内容包括&#xff1a; 1、Wireshar…

docker安装、运行

1、安装 之前有docker的话&#xff0c;需要先卸载旧版本&#xff1a; sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine 安装之前需要安装yum工具&#xff1a; sud…

Netty Review - ServerBootstrap源码解析

文章目录 概述源码分析小结 概述 ServerBootstrap bootstrap new ServerBootstrap();bootstrap.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class).option(ChannelOption.SO_BACKLOG, 1024).childHandler(new ChannelInitializer<SocketChannel>() …

Stable Diffusion 模型下载:DreamShaper(梦想塑造者)

本文收录于《AI绘画从入门到精通》专栏&#xff0c;专栏总目录&#xff1a;点这里。 文章目录 模型介绍生成案例案例一案例二案例三案例四案例五案例六案例七案例八案例九案例十 下载地址 模型介绍 DreamShaper 是一个分格多样的大模型&#xff0c;可以生成写实、原画、2.5D 等…

STM32 USART串口通信

目录 USART串口 串口发送 串口发送接收 串口收发HEX数据包 串口收发文本数据包 USART串口 串口发送 Serial.c #include "stm32f10x.h" // Device header #include "stdio.h" #include "stdarg.h"/*** brief 初始化串口以…

C++ 广度优先搜索(bfs)(五十四)【第一篇】

今天我们来学习一下一个新的搜索&#xff0c;广度优先搜索。 1.广度优先搜索的前提 队列&#xff08;queue&#xff09; 是一种 操作受限制 的线性表&#xff0c;其限制&#xff1a; 只允许从表的前端&#xff08;front&#xff09;进行删除操作&#xff1b; 只允许在表的后端…

openssl3.2 - osslsigncode工程的学习

文章目录 openssl3.2 - osslsigncode工程的学习概述笔记工程库地址工程的编译osslsigncodeM工程文件列表osslsigncodeM工程搭建细节原始工程实现的改动自己封装的包含openssl和curl的实现osslsigncodeM工程命令行的用法备注 - VS2019调试环境备注 - 如果要单步openssl的API学学…
最新文章