欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

nuxt 實現(xiàn)在其它js文件中使用store的方式

 更新時間:2020年11月05日 10:09:32   作者:Zz_糖小七  
這篇文章主要介紹了nuxt 實現(xiàn)在其它js文件中使用store的方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

前言

在新建的js文件中想用store里面的數(shù)據(jù),比如token想在封裝的axios里面,請求頭里面去使用,亦或者通過app的JS接口獲取token并存儲在store里面。

我們都知道如何在vue中如何使用。

代碼

/*
 * @Description: 
 * @Author: lxc
 * @Date: 2019-07-02 16:14:07
 * @LastEditTime: 2019-08-14 16:08:19
 * @LastEditors: lxc
 */
// 導(dǎo)出 store 的地方

import Vue from 'vue'
import Vuex from 'vuex'
import state from './state'
import actions from './actions'
import mutations from './mutations'
import getters from './getters'
import canteen from './modules/canteen'
import contact from './modules/contact'
import health from './modules/health'
import scan from './modules/scan'

Vue.use(Vuex)

let store
const initStore = () => {
 return store || (store = new Vuex.Store({
 // 存放公用數(shù)據(jù)
 state,
 // 異步操作要通過actions,否則通過cimmit直接操作mutations
 actions,
 // 同步放數(shù)據(jù)
 mutations,
 getters,
 modules: {
  // store 模塊....
 }
 }))
}
export default initStore

其它js文件中如何調(diào)用:

import store from '@/store'
const TOKEN = 'testToken'

// 這里只是舉個例子
function getToken() {
 return isNotEmpty(store().state.token) ? store().state.token : TOKEN
}

我自己使用是可以的。希望對大家有幫助。

補充知識:nuxt如何處理用戶登錄狀態(tài)持久化:nuxtServerInit 頁面渲染前的store處理

在一般的vue-cli項目中,我們可以用vuex-persistedstate,它可以使vuex的狀態(tài)持久化,頁面刷新都不會丟失,原理當(dāng)然是localStorage啦!

當(dāng)然也可以使用vue-cookies進行保存token,那么問題來了,nuxt項目怎么保存登錄狀態(tài)呢?

雖然上面這兩種方法我們都可以使用,但是有個問題,由于在created鉤子中不存在window對象(獲取cookie、localStorage都需要window對象),比如想要獲取登錄狀態(tài)即判斷是否存在token時,只能在mounted中進行操作,但這樣又會引發(fā)一個問題,就是進頁面的一瞬間還是無法得知登錄狀態(tài),體驗上會有影響,會存在顯示用戶名等組件顯示隱藏延遲。

nuxt非常友好,它提供了fetch鉤子,還有nuxtServerInit,這兩個鉤子都運行在服務(wù)端并且我們能很快速地操作store

1、fetch的使用

如果頁面組件設(shè)置了fetch方法,它會在組件每次加載前被調(diào)用(在服務(wù)端或切換至目標(biāo)路由之前),此方法需要跟服務(wù)端的人員配合

<script>
export default {
 async fetch ({ app, store, params }) {
 let { res } = app.$axios.get('/token');
 store.commit('setToken', res.data.token);
 }
}
</script>

2、nuxtServerInit

狀態(tài)樹文件中指定了nuxtServerInit方法,nuxtJs調(diào)用它的時候會將頁面的context上下文對象作為第2個參數(shù)傳給它以供服務(wù)端調(diào)用,與fetch一樣,不包括context.redirect和context.error方法,具體哪些參數(shù)可以查看官方文檔。

當(dāng)我們想要將服務(wù)端的一些數(shù)據(jù)傳到客戶端,可以通過這個獲取保存在狀態(tài)中,客戶端再從狀態(tài)里取出來就好了。

nuxtServerInit:先把token存入cookie,這樣每次請求都會自帶cookie,那么利用nuxtServerInit里的參數(shù) {req, res},去獲取到請求附帶的cookie,然后解析出token,然后再存入vuex。

推薦使用cookie插件cookie-universal-nuxt

<script>
import Vuex from 'vuex'
 
let store = () => new Vuex.Store({
 state: {
 token: ''
 },
 mutations: {
 setToken (state, token) {
  state.token = token
 }
 },
 actions: {
 nuxtServerInit({ commit }, { req }) {
  let cookie = req.headers.cookie;
 
  // 將cookie轉(zhuǎn)成json對象(自己實現(xiàn)該方法)
  let token = cookieparse(cookie).token;
  commit('setToken', token);
 },
 }
})
 
export default store
</script>

context上下文對象:

屬性 類型 可用 描述
app vue根實例 客戶端 & 服務(wù)端 包含所有插件的根實例。例如:想使用axios,可以通過context.app.$axios獲取
isClient Boolean 客戶端 & 服務(wù)端 是否來自客戶端渲染,廢棄,請使用process.client
isServer Boolean 客戶端 & 服務(wù)端 是否來自服務(wù)端渲染,廢棄,請使用process.server
isStatic Boolean 客戶端 & 服務(wù)端 是否通過nuxt generate
isDev Boolean 客戶端 & 服務(wù)端 是否開發(fā)模式,在生產(chǎn)壞境的數(shù)據(jù)緩存中用到
isHMR Boolean 客戶端 & 服務(wù)端 是否通過模塊熱替換,僅在客戶端以dev模式
route 路由 客戶端 & 服務(wù)端 路由實例
store vuex數(shù)據(jù) 客戶端 & 服務(wù)端 Vuex.sttore實例
env l Object 客戶端 & 服務(wù)端 nuxt.config.js中的環(huán)境變量
params Object 客戶端 & 服務(wù)端 route.params的別名
query Object 客戶端 & 服務(wù)端 route.query的別名
req http.Request 服務(wù)端 Node.js API的Request對象。如果nuxt以中間件形式使用的話,這個對象就根據(jù)你所使用的框架(個人理解為頁面)而定。nuxt generate 不可用
res http.Reponse 服務(wù)端 Node.js API的Reponse對象。如果nuxt以中間件形式使用的話,這個對象就根據(jù)你所使用的框架(個人理解為頁面)而定。nuxt generate 不可用
redirect Function 服務(wù)端 用于重定向另一個路由,狀態(tài)碼在服務(wù)端被使用,默認302 redirect([status,]path[,query])
error Function 客戶端 & 服務(wù)端 前往錯誤頁面,error(parmas),params包含statusCode和message字段
nuxtState Object 客戶端 nuxt狀態(tài)
beforeNuxtRender(fn) Function 服務(wù)端 更新NUXT在客戶端呈現(xiàn)的變量,具體了解請看官網(wǎng)

以上這篇nuxt 實現(xiàn)在其它js文件中使用store的方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue.js實現(xiàn)開關(guān)(switch)組件實例代碼

    vue.js實現(xiàn)開關(guān)(switch)組件實例代碼

    這篇文章介紹了vue.js實現(xiàn)開關(guān)(switch)組件的實例代碼,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • Vue.js 應(yīng)用性能優(yōu)化分析+解決方案

    Vue.js 應(yīng)用性能優(yōu)化分析+解決方案

    這篇文章主要介紹了Vue.js 應(yīng)用性能優(yōu)化分析以及解決方案,VueJS 是開發(fā)網(wǎng)站最受歡迎、最穩(wěn)定的 JavaScript 框架,但與其他框架一樣,如果您忽略它,性能就會受到影響,下面我們就一起來看看怎么才能讓性能提升吧
    2021-12-12
  • 一文了解axios和vue的整合操作

    一文了解axios和vue的整合操作

    axios作為Vue生態(tài)系統(tǒng)中濃墨重彩的一筆,我學(xué)習(xí)這個東西也是花了一定的時間的,下面這篇文章主要給大家介紹了關(guān)于axios和vue整合操作的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • vue實現(xiàn)把頁面導(dǎo)出成word文件的方法

    vue實現(xiàn)把頁面導(dǎo)出成word文件的方法

    這篇文章主要為大家詳細介紹了vue實現(xiàn)把頁面導(dǎo)出成word文件的方法,文中的實現(xiàn)步驟講解詳細,并且有詳細的代碼示例,需要的小伙伴可以參考一下
    2023-10-10
  • 分享7個成為更好的Vue開發(fā)者的技巧

    分享7個成為更好的Vue開發(fā)者的技巧

    作為使用Vue已經(jīng)很多年的人,特別是去年一直在使用?Vue3,因此,學(xué)到了很多東西。所以本文為大家準(zhǔn)備了7個讓我們成為更好?Vue?開發(fā)者的技巧,需要的可以參考一下
    2022-06-06
  • vue滾動插件better-scroll使用詳解

    vue滾動插件better-scroll使用詳解

    這篇文章主要為大家詳細介紹了vue滾動插件better-scroll,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • ant design vue中日期選擇框混合時間選擇器的用法說明

    ant design vue中日期選擇框混合時間選擇器的用法說明

    這篇文章主要介紹了ant design vue中日期選擇框混合時間選擇器的用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • vue項目中各文件的使用說明

    vue項目中各文件的使用說明

    這篇文章主要介紹了vue項目中各文件的使用說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • Vue源碼分析之Vue實例初始化詳解

    Vue源碼分析之Vue實例初始化詳解

    這篇文章主要給大家介紹了關(guān)于Vue源碼分析之Vue實例初始化的相關(guān)資料,需要的朋友可以參考下
    2019-08-08
  • 深入理解vue中的$set

    深入理解vue中的$set

    這篇文章主要介紹了深入理解vue中的$set,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06

最新評論