vue3中Pinia

news2024/11/27 16:50:33

一、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.coloradmin.cn/o/1448627.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++-带你深度理解string类的常见接口

1. 为什么学习string类&#xff1f; C语言中&#xff0c;字符串是以\0结尾的一些字符的集合&#xff0c;为了操作方便&#xff0c;C标准库中提供了一些str系列的库函数&#xff0c;但是这些库函数与字符串是分离开的&#xff0c;不太符合OOP的思想&#xff0c;而且底层空间需…

幻兽帕鲁开服教程:零基础服务器搭建超简单!

幻兽帕鲁官方服务器不稳定&#xff1f;自己搭建幻兽帕鲁服务器&#xff0c;低延迟、稳定不卡&#xff0c;目前阿里云和腾讯云均推出幻兽帕鲁专用服务器&#xff0c;腾讯云直接提供幻兽帕鲁镜像系统&#xff0c;阿里云通过计算巢服务&#xff0c;均可以一键部署&#xff0c;鼠标…

加固平板电脑丨三防智能平板丨工业加固平板丨智能城市管理

随着智能城市的不断发展&#xff0c;人们对于城市管理的要求也在不断提高&#xff0c;这就需要高效、智能的城市管理平台来实现。而三防平板就是一款可以满足这一需求的智能设备。 三防平板是一种集防水、防尘、防摔于一体的智能平板电脑&#xff0c;它可以在复杂的环境下稳定运…

点云旋转(基于PCL)

实现代码为&#xff1a; //以中心化点进行旋转double theta atan(maindirection.a);//计算的是弧度单位for (int i 0; i < origipts.size(); i){pcl::PointXYZ tempone;tempone.x aftercenerlizepts[i].x*cos(theta) aftercenerlizepts[i].y*sin(theta) center.x;temp…

【网工】华为设备命令学习(综合实验一)

实验要求和实验成果如图所示。 LSW2不需要其他配置&#xff0c;其下就一台设备&#xff0c;不需要区分。 LSW3配置如下&#xff1a; <Huawei>sy Enter system view, return user view with CtrlZ. [Huawei]un in en //关闭系统提示信息 Info: Information …

四、OpenAI之文本生成模型(Text Generation)

文本生成模型 OpenAI的文本生成模型(也叫做生成预训练的转换器(Generative pre-trained transformers)或大语言模型)已经被训练成可以理解自然语言、代码和图片的模型。模型提供文本的输出作为输入的响应。对这些模型的输入内容也被称作“提示词”。设计提示词的本质是你如何对…

在Meteor Lake平台上使用NPU进行AI推理加速

在Meteor Lake平台上&#xff0c;英特尔通过神经处理单元 (NPU) 将人工智能直接融入芯片中&#xff0c;实现桌面电脑平台的AI推理功能。神经处理单元 (NPU) 是一种专用人工智能引擎&#xff0c;专为运行持续的人工智能推理工作负载而设计。与即将推出的支持深度人工智能集成的 …

衍生式设计之随机删除Revit幕墙网格

上次教程&#xff0c;我们创建了一个随机的三角形&#xff08;一个小例子&#xff0c;告诉你什么是衍生式设计&#xff09;&#xff0c;用来给大家简单介绍了下啥是衍生式设计&#xff0c;但是三角形是在Dynamo里做的&#xff0c;似乎和Revit没啥关系&#xff0c;那么本次呢&am…

七天入门大模型 :提示词工程 Prompt Engineering,最全的总结来了!

文章目录 技术交流群用通俗易懂方式讲解系列引 言LLM 的超参配置Prompt Engineering指令主要内容少样本学习更加明确的提示善用分隔符思维链提示对输出格式的明确要求 最佳实践案例1. Agent场景&#xff1a;使用prompt实现agent create2. Agent场景&#xff1a;使用system mess…

Unresolved reference: kotlinx 和 Unresolved reference:xxx

Unresolved reference: kotlinx 这个报错是因为build.gradle中忘记apply plugin了 apply plugin: kotlin-android-extensions如下 同步以后再次编译发现报错 Unresolved reference:xxx 是因为用于使用 Gradle 构建的 Kotlin 版本与 IDE 插件中的版本不一样的原因 解决方法 …

带你了解软件系统架构的演变

随着信息技术的飞速发展&#xff0c;软件系统架构作为支撑软件系统的核心框架&#xff0c;也在不断地演变和进步。本文旨在带你了解软件系统架构的发展历程&#xff0c;从而更好地理解现代软件系统的构建和设计。 一、单体应用架构 单体应用架构是最早的软件系统架构形式&…

C语言——枚举类型

&#x1f4dd;前言&#xff1a; 在之前的文章中我们已经讲解了自定义类型中的结构体类型和联合体类型&#xff0c;现在我们再充分学习一下C语言中的枚举类型&#xff1a; 1&#xff0c;什么是枚举类型 2&#xff0c;枚举类型的定义和变量的声明 3&#xff0c;对变量进行赋值 &a…

【王道数据结构】【chapter5树与二叉树】【P158t7】

假设二叉树采用二叉链表存储结构存储&#xff0c;试设计一个算法&#xff0c;计算一颗给定二叉树的所有双分支节点的个数 #include <iostream> #include <stack> typedef struct treenode{char data;struct treenode *left;struct treenode *right; }treenode,*ptr…

FPGA_简单工程_VGA显示驱动器

一 理论 使用640*48060显示模式&#xff0c;将数字信号转换位模拟信号&#xff0c;经由VGA进行显示。 使用3GM723&#xff0c;3路高清视频编码芯片。 3GM7123编码芯片&#xff1a; 该芯片的主要功能是将RGB888的颜色数据转换成模拟的电压信号&#xff0c;然后进入到VGA接口的…

Java实现河南软件客服系统 JAVA+Vue+SpringBoot+MySQL

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 系统管理人员2.2 业务操作人员 三、系统展示四、核心代码4.1 查询客户4.2 新增客户跟进情况4.3 查询客户历史4.4 新增服务派单4.5 新增客户服务费 五、免责说明 一、摘要 1.1 项目介绍 基于JAVAVueSpringBootMySQL的河…

OpenCV 人脸检测(易上手版)

在丰富多彩的计算机视觉世界中&#xff0c;人脸检测是最有趣和最广泛应用的领域之一。无论是在安全系统、用户界面控制&#xff0c;还是在社交媒体中应用过滤器&#xff0c;准确有效地检测人脸的能力都是至关重要的。今天&#xff0c;很高兴与大家分享如何在 Python 中使用 Ope…

hadoop学习笔记

下载安装伪分布式&#xff1a; 1. 国内源下载地址&#xff1a;https://mirrors.tuna.tsinghua.edu.cn/apache/hadoop/common/ Index of /apache/hadoop/commonhttps://mirrors.tuna.tsinghua.edu.cn/apache/hadoop/common/ https://mirrors.tuna.tsinghua.edu.cn/apache/hado…

如何生成生成一个修仙世界的狗血短剧剧本

如何生成生成一个修仙世界的狗血短剧剧本 生成一个修仙世界的狗血短剧剧本将上述剧本转为对话 生成一个修仙世界的狗血短剧剧本 剧本名称&#xff1a;《仙途情缘》 角色&#xff1a; 易天行&#xff1a;男主角&#xff0c;天赋异禀的修仙者&#xff0c;性格坚毅&#xff0c;正…

(免费领源码)Java#MySql#hadoop高校固定资产管理系统74965-计算机毕业设计项目选题推荐

摘 要 在信息飞速发展的今天&#xff0c;网络已成为人们重要的信息交流平台。高校部门每天都有大量的信息需要通过网络发布&#xff0c;为此&#xff0c;高校固定资产管理系统开发的必然性&#xff0c;所以本人开发了一个基于Tomcat&#xff08;服务器&#xff09;模式的高校固…

C语言-----用二维数组解决菱形的打印问题

1.打印菱形&#xff0c;多组输入&#xff0c;一个整数&#xff08;2~20&#xff09;&#xff0c;表示输出的行数&#xff0c;也表示组成“X”的反斜线和正斜线的长度。 #include <stdio.h>int main() {int n0;while(scanf("%d",&n)! EOF){int i0;int j0;f…