国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Vite4+Typescript+Vue3+Pinia 從零搭建(6) - 狀態(tài)管理pina

這篇具有很好參考價值的文章主要介紹了Vite4+Typescript+Vue3+Pinia 從零搭建(6) - 狀態(tài)管理pina。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

項目代碼同步至碼云 weiz-vue3-template
pina 是 vue3 官方推薦的狀態(tài)管理庫,由 Vue 核心團隊維護,旨在替代 vuex。pina 的更多介紹,可從 pina官網(wǎng) 查看

特點

  • 更簡潔直接的 API,提供組合式風格的 API
  • 支持模塊熱更新和服務端渲染
  • 對TS支持更為友好

安裝

npm i pinia

使用

1. 創(chuàng)建實例

src目錄下新建store文件夾,并新建index.ts文件

import { createPinia } from 'pinia'

const store = createPinia()

export default store

2. 使用實例

在main.ts里引入并使用

import { createApp } from 'vue'
import pinia from '@/store'
import './style.css'
import App from './App.vue'

import router from '@/router/index'

createApp(App).use(router).use(pinia).mount('#app')

3. 創(chuàng)建store

types文件夾下創(chuàng)建store.ts類型聲明

export interface UserState {
  token: string
  userInfo: { name?: string; phone?: string }
}

store目錄下新建modules文件夾,并新建user.ts文件

import { defineStore } from 'pinia'
import { UserState } from 'types/store'

// 第一個參數(shù)是id,唯一
export const useUserStore = defineStore('user', {
  state: () => {
    return {
      token: 'EFA68205747CB561BB7C0F85D5689856',
      userInfo: { name: 'weizwz', phone: '18392016879' }
    }
  },
  getters: {
    namePic: (state) => state.userInfo.name.substring(0, 1)
  },
  actions: {
    setToken(token: string) {
      this.token = token
    },
    setUserInfo(userInfo: UserState['userInfo']) {
      this.userInfo = { ...this.userInfo, ...userInfo }
    }
  }
})

4. 使用store

修改view文件夾下的home.vue來獲取store

<script setup lang="ts">
import { computed } from 'vue'
import { storeToRefs } from 'pinia'
import { useUserStore } from '@store/user'

defineOptions({
  name: 'V-home'
})

const userStore = useUserStore()
// 獲取state使用computed或者使用storeToRefs,直接使用不具備響應式(拿到的永遠是初次的值)
const username = computed(() => userStore.userInfo.name)
// 獲取getter使用storeToRefs,或者直接使用,在模板里 userStore.namePic
const { namePic, token } = storeToRefs(userStore)
</script>

<template>
  <div>Hello: {{ namePic }}, your name is {{ username }}, your token is {{ token }}</div>
</template>

<style scoped></style>

修改view文件夾下的login.vue來設置store

<script setup lang="ts">
import { ref } from 'vue'
import { storeToRefs } from 'pinia'
import { useUserStore } from '@store/user'

defineOptions({
  name: 'V-login'
})

const userStore = useUserStore()
const { userInfo, token } = storeToRefs(userStore)
const userName = ref(userInfo.value.name)
const userToken = ref(token)

const updateUserName = () => {
  userStore.setUserInfo({
    name: userName.value
  })
}
const updateUserToken = () => {
  userStore.setToken(userToken.value)
}
</script>

<template>
  <div>login page</div>
  name:
  <input type="text" v-model="userName" @input="updateUserName" />
  <br />
  token:
  <input type="text" v-model="userToken" @input="updateUserToken" />
</template>

<style scoped></style>

如果@store/user不能識別,請在tsconfig.json中的paths里加入此路徑

"paths": {
  "@store/*": ["src/store/modules/*"],
},

持久化

由于刷新界面會導致store重置,所以一般通過將store存儲到cookie或者storage里使其持久化。cookie方面的插件,我這里推薦使用js-cookie

1. 安裝

npm i js-cookie -S
npm i @types/js-cookie -S

2.封裝

在src下新建utils文件夾,并新建auth.ts

import Cookies from 'js-cookie'

export const TokenKey = 'weiz-token'

type ExpiresData = Date | number
export interface TokenInfo {
  token: string
  expires: ExpiresData
}

export function getToken() {
  return Cookies.get(TokenKey)
}

export function setToken(data: TokenInfo) {
  const { token, expires } = data
  return expires ? Cookies.set(TokenKey, token, { expires: expires }) : Cookies.set(TokenKey, token)
}

export function removeToken() {
  return Cookies.remove(TokenKey)
}

3. 使用

修改store下的user.ts

import { getToken, setToken } from '@/utils/auth'
// 省略
state: () => {
  return {
    token: getToken() || 'EFA68205747',
    userInfo: { name: 'weizwz', phone: '18392016879' }
  }
}
// 省略
setToken(token: string) {
  this.token = token
  setToken({
    token,
    expires: 30
  })
}

效果展示

Vite4+Typescript+Vue3+Pinia 從零搭建(6) - 狀態(tài)管理pina文章來源地址http://www.zghlxwxcb.cn/news/detail-748495.html

到了這里,關于Vite4+Typescript+Vue3+Pinia 從零搭建(6) - 狀態(tài)管理pina的文章就介紹完了。如果您還想了解更多內容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如若轉載,請注明出處: 如若內容造成侵權/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領支付寶紅包贊助服務器費用

相關文章

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領取紅包,優(yōu)惠每天領

二維碼1

領取紅包

二維碼2

領紅包