您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
simple state manager based on Vue3.reactive and localStorage
当前为
// ==UserScript== // @name persistent-state // @description simple state manager based on Vue3.reactive and localStorage // @namespace http://tampermonkey.net/ // @author smartacephale // @license MIT // @version 1.0 // @match *://*/* // ==/UserScript== /* globals reactive, watch */ class PersistentState { constructor(state, key = "state_acephale") { this.key = key; this.state = reactive(state); this.sync(); this.watchPersistence(); } sync() { this.trySetFromLocalStorage(); window.addEventListener('focus', this.trySetFromLocalStorage); } watchPersistence() { watch(this.state, (value) => { this.saveToLocalStorage(this.key, value); }); } saveToLocalStorage(key, value) { localStorage.setItem(key, JSON.stringify(value)); } trySetFromLocalStorage = () => { const localStorageValue = localStorage.getItem(this.key); if (localStorageValue !== null) { const prevState = JSON.parse(localStorageValue); for (const prop of Object.keys(prevState)) { this.state[prop] = prevState[prop]; } } } }