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

vue調(diào)用本地緩存方式(監(jiān)視數(shù)據(jù)變更)

 更新時間:2022年04月29日 15:49:32   作者:LuiChun  
這篇文章主要介紹了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中keep-alive緩存組件的理解

    淺析對Vue中keep-alive緩存組件的理解

    <keep-alive> 是一個抽象組件,用于將其內(nèi)部的組件保留在內(nèi)存中,而不會重新渲染,這意味著當(dāng)組件在<keep-alive> 內(nèi)部切換時,其狀態(tài)將被保留,而不是被銷毀和重新創(chuàng)建,這篇文章主要介紹了Vue中的keep-alive緩存組件的理解,需要的朋友可以參考下
    2024-01-01
  • Vue項目打包到服務(wù)器后請求接口報錯404的解決

    Vue項目打包到服務(wù)器后請求接口報錯404的解決

    這篇文章主要介紹了Vue項目打包到服務(wù)器后請求接口報錯404的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vue實現(xiàn)網(wǎng)頁語言國際化切換

    vue實現(xiàn)網(wǎng)頁語言國際化切換

    這篇文章介紹了vue實現(xiàn)網(wǎng)頁語言國際化切換的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-11-11
  • vue-admin-template模板添加tagsview的實現(xiàn)

    vue-admin-template模板添加tagsview的實現(xiàn)

    本文主要介紹了vue-admin-template模板添加tagsview的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • vue查找指令和模板思路詳解

    vue查找指令和模板思路詳解

    這篇文章主要介紹了vue查找指令和模板,基本思路是需要判斷當(dāng)前遍歷到的節(jié)點是一個元素還是一個文本,隨著思路的展開我們就來實現(xiàn)這個功能,需要的朋友可以參考下
    2023-10-10
  • vue.js組件vue-waterfall-easy實現(xiàn)瀑布流效果

    vue.js組件vue-waterfall-easy實現(xiàn)瀑布流效果

    這篇文章主要為大家詳細(xì)介紹了vue.js實現(xiàn)瀑布流之vue-waterfall-easy的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • vue?實現(xiàn)左滑圖片驗證功能

    vue?實現(xiàn)左滑圖片驗證功能

    網(wǎng)頁中滑動圖片驗證一直是各大網(wǎng)站、移動端的主流校驗方式,其主要作用是為了區(qū)分人和機器以及為了防止機器人程序暴力登錄或攻擊從而設(shè)置的一種安全保護方式,這篇文章主要介紹了vue?實現(xiàn)左滑圖片驗證,需要的朋友可以參考下
    2023-04-04
  • vue+element-ui動態(tài)生成多級表頭的方法

    vue+element-ui動態(tài)生成多級表頭的方法

    今天小編就為大家分享一篇vue+element-ui動態(tài)生成多級表頭的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Vue?CompositionAPI中watch和watchEffect的區(qū)別詳解

    Vue?CompositionAPI中watch和watchEffect的區(qū)別詳解

    這篇文章主要為大家詳細(xì)介紹了Vue?CompositionAPI中watch和watchEffect的區(qū)別,文中的示例代碼簡潔易懂,希望對大家學(xué)習(xí)Vue有一定的幫助
    2023-06-06
  • vue+element 模態(tài)框表格形式的可編輯表單實現(xiàn)

    vue+element 模態(tài)框表格形式的可編輯表單實現(xiàn)

    這篇文章主要介紹了vue+element 模態(tài)框表格形式的可編輯表單實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-06-06

最新評論