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

Vuex結合storage實現(xiàn)用戶信息本地存儲方式

 更新時間:2022年04月29日 14:51:43   作者:五顏六色的黑  
這篇文章主要介紹了Vuex結合storage實現(xiàn)用戶信息本地存儲方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

自己學習的過程中遇到用戶新的填寫的頁面,所以就想著頁面每次刷新之后總不能一直填寫,哇,累死,所以就想到了離線存儲機制,這里使用的是good-storage封裝庫結合Vuex來實現(xiàn)這個功能,在此做個筆記。

首先安裝插件庫good-storage

npm install good-storage

在你寫離線存儲邏輯部分的地方引入good-storage

盤它。吶~,吶~下面是我寫的用戶部分信息的存儲邏輯

import storage from "good-storage" ? ?//引入
const USER_DATAS="__userdatas__" ? ? ?//定義鍵值
?
//用戶信息存儲,這里傳入一個參數(shù)是個對象
export function saveUserData(obj){
?? ?let userDatas=storage.get(USER_DATAS,{}); ? //獲取存儲的值,若沒有,返回一個空對象
?? ?if(obj.phone){
?? ??? ?userDatas.phone=obj.phone;
?? ?}
?? ?if(obj.name){
?? ??? ?userDatas.name=obj.name;
?? ?}
?? ?if(obj.sex){
?? ??? ?userDatas.sex=obj.sex;
?? ?}
?? ?if(obj.education){
?? ??? ?userDatas.education=obj.education;
?? ?}
?? ?if(obj.industry){
?? ??? ?userDatas.industry=obj.industry;
?? ?}
?? ?storage.set(USER_DATAS,userDatas);
?? ?return userDatas;
}
?
//獲取用戶本地存儲的信息,如果沒有存儲過,返回一個空對象
export function loaduserDatas(){
?? ?return storage.get(USER_DATAS,{});
}

接下來是定義vuex的代碼部分

state.js如下

import {loaduserDatas} from "common/js/cache" ?//這里按照自己的路徑引入進去
const state={
?? ?user_datas:loaduserDatas() ? ? ? //獲取到用戶信息
}
export default state

getters.js 映射state中的數(shù)據(jù),方便在外部組建中引入數(shù)據(jù)

export const user_datas = state => state.user_datas;

mutation-types.js    

export const SET_USERDATA="SET_USERDATA"

mutaion.js提交修改之后的obj對象,即用戶信息

import * as types from "./mutation-types.js"
const mutations={
?? ?[types.SET_USERDATA](state,obj){
?? ??? ?state.user_datas=obj
?? ?}
}
export default mutations;

actions.js 因為有可能同時修改多個用戶信息內容,所以這里選擇使用action進行異步操作,提交mutation

//同樣按照自己的目錄引入所需文件
?
import {saveUserData} from "common/js/cache"
import * as types from "./mutation-types.js"
export const saveUserDatas=function({commit},obj){
?? ?commit(types.SET_USERDATA,saveUserData(obj))
}

在外部組件中的操作如下

我的文件是datum.vue

datum.vue 

<script>
import {mapGetters,mapActions} from "vuex";
export default{
?? ? data() {
?? ? ? ?return {
?? ? ? ? ?dateStr:this.userName,
?? ? ? ? ?showDate:false,
?? ? ? ? ?nickName:"",
?? ? ? ? ?revise:false,
?? ? ? ? ?showNicknameMod:false,
?? ? ? ? ?userDatasObj:{
?? ? ? ? ??? ?name:"",
?? ? ? ? ??? ?phone:'18419954234',
?? ? ? ? ??? ?sex:'',
?? ? ? ? ??? ?education:'本科',
?? ? ? ? ??? ?industry:'互聯(lián)網(wǎng)電子商務'
?? ? ? ? ?}
?? ? ? ?}
?? ? ?},
?
?? ? ?computed:{
?? ? ??? ?selectedDate(){
?? ? ??? ??? ?return this.showDate ? this.dateStr : this.userName ;
?? ? ??? ?},
?? ? ??? ?_nickName(){
?? ? ??? ??? ?if(this.revise){
?? ? ??? ??? ??? ?return this.nickName;
?? ? ??? ??? ?}else{
?? ? ??? ??? ??? ?if( !this.user_datas.name){
?? ? ??? ??? ??? ??? ?return "請輸入昵稱"
?? ? ??? ??? ??? ?}?
?? ? ??? ??? ??? ?else{
?? ? ??? ??? ??? ??? ?return this.user_datas.name
?? ? ??? ??? ??? ?}
?? ? ??? ??? ?}
?? ? ??? ?},
?? ? ??? ?_sex(){
?? ? ??? ??? ?if(!this.user_datas.sex){
?? ? ??? ??? ??? ?return "請選擇"
?? ? ??? ??? ?}
?? ? ??? ??? ?return this.userDatasObj.sex=this.user_datas.sex;
?? ? ??? ?},
?? ? ??? ?_selectEdu(){
?? ? ??? ??? ?if(!this.user_datas.education){
?? ? ??? ??? ??? ?return "請選擇"
?? ? ??? ??? ?}
?? ? ??? ??? ?return this.userDatasObj.education=this.user_datas.education;
?? ? ??? ?},
?? ? ??? ?_industry(){
?? ? ??? ??? ?if(!this.user_datas.industry){
?? ? ??? ??? ??? ?return "請選擇"
?? ? ??? ??? ?}
?? ? ??? ??? ?return this.userDatasObj.industry=this.user_datas.industry;
?? ? ??? ?},
? ? ? ??
? ? ? ? //獲取到用戶原來的信息,并進行相應的邏輯判斷,看自己的情況哈。以上是我個人的
?? ? ??? ?...mapGetters([
?? ? ??? ??? ?"user_datas"
?? ? ??? ?])
?? ? ?},
?? ??? ?methods:{
? ??? ??? ??? ?
? ? ?? ??? ?savedInfo(){
? ? ?? ??? ??? ?this.saveUserDatas(this.userDatasObj);
? ? ?? ??? ??? ?
? ? ?? ??? ?},
?
? ? ? ? ? ? //引入action中的提交信息操作,在保存信息的時候直接調用,傳入信息對象參數(shù)
?? ??? ? ??? ?...mapActions([
?? ??? ? ??? ??? ?"saveUserDatas"
?? ??? ? ??? ?])
?? ??? ?},
?? ?}
</script>

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • vue 中this.$set 動態(tài)綁定數(shù)據(jù)的案例講解

    vue 中this.$set 動態(tài)綁定數(shù)據(jù)的案例講解

    這篇文章主要介紹了vue 中this.$set 動態(tài)綁定數(shù)據(jù)的案例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • Vue數(shù)據(jù)表格增刪改查與表單驗證代碼詳解

    Vue數(shù)據(jù)表格增刪改查與表單驗證代碼詳解

    這篇文章主要給大家介紹了關于Vue數(shù)據(jù)表格增刪改查與表單驗證的相關資料,Vue可以通過使用組件化的方式來實現(xiàn)表格的增刪改查功能,文中通過圖文以及代碼介紹的非常詳細,需要的朋友可以參考下
    2023-10-10
  • vue實現(xiàn)單選和多選功能

    vue實現(xiàn)單選和多選功能

    這篇文章主要為大家詳細介紹了vue實現(xiàn)單選和多選功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 詳解vue3的沙箱機制

    詳解vue3的沙箱機制

    這篇文章主要介紹了vue3的沙箱機制的相關資料,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下
    2021-04-04
  • vue如何使用rem適配

    vue如何使用rem適配

    這篇文章主要介紹了vue如何使用rem適配,幫助大家處理vue開發(fā)移動應用時的兼容性問題,感興趣的朋友可以了解下
    2021-02-02
  • vue組件中使用iframe元素的示例代碼

    vue組件中使用iframe元素的示例代碼

    本篇文章主要介紹了vue組件中使用iframe元素的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • setTimeout在vue中的正確使用方式

    setTimeout在vue中的正確使用方式

    這篇文章主要介紹了setTimeout在vue中的正確使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue 解決data中定義圖片相對路徑頁面不顯示的問題

    vue 解決data中定義圖片相對路徑頁面不顯示的問題

    這篇文章主要介紹了vue 解決data中定義圖片相對路徑頁面不顯示的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue中用qrcode庫將超鏈接生成二維碼圖片的示例代碼

    vue中用qrcode庫將超鏈接生成二維碼圖片的示例代碼

    生成二維碼是一種常見的需求,無論是用于商業(yè)宣傳還是個人分享,二維碼都可以提供快速方便的方式來傳遞信息,在Vue框架中,我們可以使用qrcode庫來輕松地生成二維碼,本篇博文將介紹如何安裝qrcode庫,并通過一個實際例子來展示如何生成二維碼,需要的朋友可以參考下
    2023-12-12
  • vue的table表格組件的封裝方式

    vue的table表格組件的封裝方式

    這篇文章主要介紹了vue的table表格組件的封裝方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06

最新評論