vue調(diào)用本地緩存方式(監(jiān)視數(shù)據(jù)變更)
vue調(diào)用本地緩存
深度監(jiān)視
為了發(fā)現(xiàn)對(duì)象內(nèi)部值的變化,可以再選項(xiàng)參數(shù)中指定deep:true; [監(jiān)聽數(shù)組的變動(dòng)不需要這樣]
使用方法
handler其值是true一個(gè)回調(diào)函數(shù),即監(jiān)聽到變化時(shí)應(yīng)該執(zhí)行的函數(shù)deep其值是true或false,確認(rèn)是否為深入監(jiān)聽(一般監(jiān)聽時(shí)不能監(jiān)聽到對(duì)象屬性值的變化,數(shù)組的值的變化可以監(jiān)聽到)immediate其值是true或者false,確認(rèn)是否以當(dāng)前的初始值執(zhí)行handler的函數(shù)

配置新的工具文件夾
配置緩存文件

接收數(shù)據(jù)頁面
<template> ? <div> ? ? <!-- 添加增加方法 ?傳遞給子組件--> ? ? <Shijian :addTodo="addTodo" /> ? ? <!-- 傳遞給子組件數(shù)據(jù) --> ? ? <!-- 傳遞刪除方法 子組件--> ? ? <Shijianone :todos="todos" :delTodo="delTodo" /> ? ? <!-- 傳遞給子組件 --> ? ? <Shijiantwo ? ? ? :todos="todos" ? ? ? :selectedAllTodo="selectedAllTodo" ? ? ? :delFinishedTodos="delFinishedTodos" ? ? /> ? </div> </template>
<script scoped>
import Shijian from "@/components/Shijian";
import Shijianone from "@/components/Shijianone";
import Shijiantwo from "@/components/Shijiantwo";
import localStorageUtil from "@/utils/localStorageUtil";
export default {
? name: "Body",
? data() {
? ? return {
? ? ? todos: localStorageUtil.readTodos(),
? ? };
? },
? components: {
? ? Shijian,
? ? Shijianone,
? ? Shijiantwo,
? },
? // 添加刪除方法
? // 添加增加方法
? methods: {
? ? // 插入數(shù)據(jù) ? 參數(shù)為(數(shù)據(jù))
? ? addTodo(todo) {
? ? ? // 傳遞數(shù)據(jù) (todo)
? ? ? this.todos.unshift(todo);
? ? },
? ? delTodo(index) {
? ? ? // 刪除一條
? ? ? this.todos.splice(index, 1);
? ? },
? ? // 是否選中所有任務(wù)
? ? selectedAllTodo(isCheck) {
? ? ? this.todos.forEach((todo) => {
? ? ? ? todo.finished = isCheck;
? ? ? });
? ? },
? ? // 選中刪除的方法
? ? delFinishedTodos() {
? ? ? this.todos = this.todos.filter((todo) => !todo.finished);
? ? },
? },
? watch: {
? ? // 深度監(jiān)視
? ? todos: {
? ? ? // 一旦監(jiān)聽到變化,就保存到本地
? ? ? // .saveTodos加了()會(huì)報(bào)錯(cuò)
? ? ? // 執(zhí)行保存操作
? ? ? handler: localStorageUtil.saveTodos,
? ? ? // deep: true,深度監(jiān)視
? ? ? deep: true,
? ? ? // immediate為true 一進(jìn)來就執(zhí)行handler函數(shù)
? ? ? immediate: true,
? ? },
? },
};
</script><style scoped> </style>
配置緩存文件內(nèi)容
const LKTODO ='lktodo';
export default{
readTodos(){
return JSON.parse(localStorage.getItem(LKTODO) ||'[]')
},
saveTodos(todos){
// 下面這行只是為了打印一下
console.log(todos);
localStorage.setItem(LKTODO, JSON.stringify(todos));
}
}
vue監(jiān)聽緩存事件
隨著H5的更新,前端經(jīng)常使用本地存儲(chǔ)進(jìn)行交互處理數(shù)據(jù),如果想要監(jiān)聽緩存的變化,以下代碼就是您想要的。
在main創(chuàng)建緩存事件
// 監(jiān)聽緩存事件
Vue.prototype.$addStorageEvent = function(type, key, data) {
if (type === 1) {
// 創(chuàng)建一個(gè)StorageEvent事件
var newStorageEvent = document.createEvent("StorageEvent");
const storage = {
setItem: function(k, val) {
localStorage.setItem(k, val);
// 初始化創(chuàng)建的事件
newStorageEvent.initStorageEvent(
"storageItem",
false,
false,
k,
null,
val,
null,
null
);
// 派發(fā)對(duì)象
window.dispatchEvent(newStorageEvent);
},
};
return storage.setItem(key, data);
} else {
// 創(chuàng)建一個(gè)StorageEvent事件
var newStorageEvent = document.createEvent("StorageEvent");
const storage = {
setItem: function(k, val) {
sessionStorage.setItem(k, val);
// 初始化創(chuàng)建的事件
newStorageEvent.initStorageEvent(
"setItem",
false,
false,
k,
null,
val,
null,
null
);
// 派發(fā)對(duì)象
window.dispatchEvent(newStorageEvent);
},
};
return storage.setItem(key, data);
}
};在組件生命周期中 監(jiān)聽緩存事件并取值
? ? window.addEventListener(
? ? ? "stotageItem",
? ? ? (e) => { // e代表存儲(chǔ)的數(shù)據(jù) { a:1 }
? ? ? ? JSON.parse(e.a)
? ? ? },
? ? ? false
? ? );在組件業(yè)務(wù)代碼 進(jìn)行緩存使用
?this.$addStorageEvent(0, "useStorage",?
? ? // 寫入數(shù)據(jù)
? ? JSON.stringify({ a:1 })
?);以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解webpack打包vue項(xiàng)目之后生成的dist文件該怎么啟動(dòng)運(yùn)行
這篇文章主要介紹了詳解webpack打包vue項(xiàng)目之后生成的dist文件該怎么啟動(dòng)運(yùn)行,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
vue使用Vue.extend創(chuàng)建全局toast組件實(shí)例
這篇文章主要介紹了vue使用Vue.extend創(chuàng)建全局toast組件實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
基于Vue+Node.js實(shí)現(xiàn)埋點(diǎn)功能全流程
埋點(diǎn)(Track)是指在應(yīng)用程序、網(wǎng)站或平臺(tái)中添加代碼,以記錄特定用戶行為和事件的做法,通過添加埋點(diǎn)代碼,可以觀察和分析用戶行為,以調(diào)整和改進(jìn)產(chǎn)品設(shè)計(jì)和使用體驗(yàn),本文給大家介紹了基于Vue+Node.js實(shí)現(xiàn)埋點(diǎn)功能的全流程,需要的朋友可以參考下2025-04-04
vue+el-table實(shí)現(xiàn)合并單元格
這篇文章主要為大家詳細(xì)介紹了vue+el-table實(shí)現(xiàn)合并單元格,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
VUE前端實(shí)現(xiàn)token的無感刷新3種方案(refresh_token)
這篇文章主要給大家介紹了關(guān)于VUE前端實(shí)現(xiàn)token的無感刷新3種方案(refresh_token)的相關(guān)資料,為了提供更好的用戶體驗(yàn),我們可以通過實(shí)現(xiàn)Token的無感刷新機(jī)制來避免用戶在使用過程中的中斷,需要的朋友可以參考下2023-11-11
Vue中Video標(biāo)簽播放解析后短視頻去水印無響應(yīng)解決
這篇文章主要為大家介紹了Vue中使用Video標(biāo)簽播放?<解析后的短視頻>去水印視頻無響應(yīng)的解決方式,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04

