vue3中的pinia(大菠萝)

和vue2中vuex用法类似

pinia中包含了 state:存放数据   getters:计算属性  actions:方法(可处理同/异步)

首先在项目中安装引入

npm i pinia

main.js中挂载

import './assets/main.css'
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import Vant from 'vant'
import 'vant/lib/index.css'

import { createPinia } from 'pinia'  //1.引入pinia


const app = createApp(App)
const pinia = createPinia()   //2.注册

app.use(router)
app.use(Vant)
app.use(pinia)   //3.使用

app.mount('#app')

src>创建store文件夹>创建××.js文件

import { defineStore } from "pinia";

export const useAppStore = defineStore('use', {
  state: () => ({
    pinias: '3',
    avatar: 'https://baidu.com'
  }),
  // 计算属性
  getters: {
    // changepinias: (state) => {
    //   return state.pinias >= '3' ? '大于3' : '小于3'
    // }
    // 简写
    changepinias: state => state.pinias >= '3' ? '大于3' : '小于3',
  },
  // 方法 可处理同步和异步
  actions: {
    addpinias: state => {
      console.log(state);
    }
  }

})

页面中使用

引用

//1.引入文件和所需pinia的方法
import { storeToRefs } from 'pinia';
import { useAppStore } from "@/store/app.js"

使用state


//2.使用
const store = useAppStore()  //store是一个reactive响应式对象
//普通修改值是响应式的
store.pinias = 4

//结构赋值,可以修改需要对元数据进行修改 并且不是响应式  使用storeToRefs
//const { pinias, avatat } = storeToRefs(store)
// store.pinias = '666'
//console.log(store.pinias, 'pinia的结构---');

修改值$patch()

store.$patch((state) => {
  state.pinias = '7878',
    state.avatar = 'http://localhost:5173/ncishcv-app/visitingcard'
})
console.log(store.pinias, store.avatar, '--');

重置值$reset()

// 重置state所有值  $reset()
 store.$reset()
 console.log(store.pinias, store.avatar, '--');

使用getters

// 读取getters  计算出结果
console.log(store.changepinias);

使用actions

console.log(store.addpinias());

你可以按照以下步骤在Vue3中安装Pinia: 1. 使用npm或yarn安装Pinia依赖: ``` npm install pinia ``` 或者 ``` yarn add pinia ``` 2. 在你的main.ts文件中引入Pinia构造函数: ```typescript import { createPinia } from &#39;pinia&#39; ``` 3. 实例化Pinia: ```typescript const pinia = createPinia() ``` 4. 在Vue应用程序中使用Pinia: ```typescript const app = createApp(App); app.use(pinia).mount(&#39;#app&#39;) ``` 现在你已经成功安装并配置了Pinia,你可以在你的Vue3应用程序中使用它进行状态管理。如果你需要详细的安装和使用说明,你可以查看Pinia的官方文档:<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue3pinia(大菠萝)](https://blog.csdn.net/longyan_tianyu/article/details/129450618)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Vue3中使用Pinia详解](https://blog.csdn.net/w137160164/article/details/131160122)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [vue3Pinia初识与安装](https://blog.csdn.net/weixin_55323831/article/details/127057825)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值