vue中,在本地缓存中读写数据的方法

1.安装good-storage插件

2.读/写的方法

common/js/cache.js:

const SEARCH_KEY = 'search'
const SEARCH_MAX_LENGTH = 15

// compare:findindex传入的是function,所以不能直接传val
function insertArray(arr,val,compare,maxLen) {
const index = arr.findIndex(compare)
if (index === 0) {
return
}
if (index > 0) {
arr.splice(index,1)
}
arr.unshift(val) // 插入到数组最前
if (maxLen && arr.length > maxLen) {
arr.pop() // 删除末位元素
}
}

// 存储搜索历史
export function saveSearch(query) {
let searches = storage.get(SEARCH_KEY,[])
insertArray(searches,query,(item) => {
return item === query
},SEARCH_MAX_LENGTH)
storage.set(SEARCH_KEY,searches)
return searches
}
// 加载本地缓存的搜索历史
export function loadSearch() {
return storage.get(SEARCH_KEY,[])
}

3.数据用vuex传递

在store/actions.js中写入数据:

export const saveSearchHistory = function({commit,state},query) {
commit(types.SET_SEARCH_HISTORY,saveSearch(query))
}

4.组件中调用vuex

// methods内:
saveSearch() {
this.saveSearchHistory(this.query)
},...mapActions([
'saveSearchHistory'
])

以上这篇vue中,在本地缓存中读写数据的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

相关文章

这篇文章我们将通过debug源码的方式来带你搞清楚defineAsync...
欧阳老老实实的更新自己的高质量vue源码文章,还被某2.6k st...
前言 在Vue3.5版本中响应式 Props 解构终于正式转正了,这个...
组合式 (Composition) API 的一大特点是“非常灵活”,但也因...
相信你最近应该看到了不少介绍Vue Vine的文章,这篇文章我们...
前言 在欧阳的上一篇 这应该是全网最详细的Vue3.5版本解读文...