vue調(diào)用本地緩存方式(監(jiān)視數(shù)據(jù)變更)
vue調(diào)用本地緩存
深度監(jiān)視
為了發(fā)現(xiàn)對象內(nèi)部值的變化,可以再選項參數(shù)中指定deep:true; [監(jiān)聽數(shù)組的變動不需要這樣]
使用方法
handler其值是true一個回調(diào)函數(shù),即監(jiān)聽到變化時應(yīng)該執(zhí)行的函數(shù)deep其值是true或false,確認是否為深入監(jiān)聽(一般監(jiān)聽時不能監(jiān)聽到對象屬性值的變化,數(shù)組的值的變化可以監(jiān)聽到)immediate其值是true或者false,確認是否以當(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加了()會報錯
? ? ? // 執(zhí)行保存操作
? ? ? handler: localStorageUtil.saveTodos,
? ? ? // deep: true,深度監(jiān)視
? ? ? deep: true,
? ? ? // immediate為true 一進來就執(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)常使用本地存儲進行交互處理數(shù)據(jù),如果想要監(jiān)聽緩存的變化,以下代碼就是您想要的。
在main創(chuàng)建緩存事件
// 監(jiān)聽緩存事件
Vue.prototype.$addStorageEvent = function(type, key, data) {
if (type === 1) {
// 創(chuàng)建一個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ā)對象
window.dispatchEvent(newStorageEvent);
},
};
return storage.setItem(key, data);
} else {
// 創(chuàng)建一個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ā)對象
window.dispatchEvent(newStorageEvent);
},
};
return storage.setItem(key, data);
}
};在組件生命周期中 監(jiān)聽緩存事件并取值
? ? window.addEventListener(
? ? ? "stotageItem",
? ? ? (e) => { // e代表存儲的數(shù)據(jù) { a:1 }
? ? ? ? JSON.parse(e.a)
? ? ? },
? ? ? false
? ? );在組件業(yè)務(wù)代碼 進行緩存使用
?this.$addStorageEvent(0, "useStorage",?
? ? // 寫入數(shù)據(jù)
? ? JSON.stringify({ a:1 })
?);以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue-admin-template模板添加tagsview的實現(xiàn)
本文主要介紹了vue-admin-template模板添加tagsview的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
vue.js組件vue-waterfall-easy實現(xiàn)瀑布流效果
這篇文章主要為大家詳細介紹了vue.js實現(xiàn)瀑布流之vue-waterfall-easy的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08
vue+element-ui動態(tài)生成多級表頭的方法
今天小編就為大家分享一篇vue+element-ui動態(tài)生成多級表頭的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08
Vue?CompositionAPI中watch和watchEffect的區(qū)別詳解
這篇文章主要為大家詳細介紹了Vue?CompositionAPI中watch和watchEffect的區(qū)別,文中的示例代碼簡潔易懂,希望對大家學(xué)習(xí)Vue有一定的幫助2023-06-06
vue+element 模態(tài)框表格形式的可編輯表單實現(xiàn)
這篇文章主要介紹了vue+element 模態(tài)框表格形式的可編輯表單實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-06-06

