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,確認(rèn)是否為深入監(jiān)聽(一般監(jiān)聽時不能監(jiān)聽到對象屬性值的變化,數(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加了()會報錯 ? ? ? // 執(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),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04vue.js組件vue-waterfall-easy實現(xiàn)瀑布流效果
這篇文章主要為大家詳細(xì)介紹了vue.js實現(xiàn)瀑布流之vue-waterfall-easy的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08vue+element-ui動態(tài)生成多級表頭的方法
今天小編就為大家分享一篇vue+element-ui動態(tài)生成多級表頭的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08Vue?CompositionAPI中watch和watchEffect的區(qū)別詳解
這篇文章主要為大家詳細(xì)介紹了Vue?CompositionAPI中watch和watchEffect的區(qū)別,文中的示例代碼簡潔易懂,希望對大家學(xué)習(xí)Vue有一定的幫助2023-06-06vue+element 模態(tài)框表格形式的可編輯表單實現(xiàn)
這篇文章主要介紹了vue+element 模態(tài)框表格形式的可編輯表單實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-06-06