油猴实现 全局变量 跨标签页共享变量 的方法

本文介绍了如何利用浏览器脚本的GM_setValue和GM_getValue函数实现在页面间的变量共享。通过示例展示了设置和获取存储对象的用法,以及这些数据在Chrome内置的LevelDB中的存储位置。此外,还讨论了不同Chrome实例之间数据存储的独立性,确保了数据的安全使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需求

从页面A获取到数据,但是在跳转到页面B后数据则消失。所以希望能够跨标签共享变量。

思路

使用GM_setValueGM_getValue来实现。

介绍

官方定义:

GM_setValue(name, value)
Set the value of 'name' to the storage.

GM_getValue(name, defaultValue)
Get the value of 'name' from storage.

详细wiki: GM.setValue - GreaseSpot Wiki

使用

首先在脚本开头加上这两行

// @grant        GM_setValue
// @grant        GM_getValue

之后看个例子

(function() {
    'use strict';

    // Your code here...
    var a = {
        'name': '兔子昂'
    };

    GM_setValue('zw_test', a);
    console.log(GM_getValue('zw_test'));
    console.log(GM_getValue('zw_test').name);
})();

Chrome 的 console 输出

{name: "兔子昂"}
兔子昂

说明可以方便的将对象存储,并读取,非常方便。

扩展

GM_setValue 将数据存储在哪里?
存储在 Chrome 内置的 LevelDB 中。

多个 Chrome 同时开启是否会导致 GM_setValue 对同一个 key 相互覆盖?

在 Chrome A 实例下 set value A, 然后在 Chrome B 实例下 get value A。
会发现 Chrome B 读出来的结果是 undefined。
可以放心使用了。


参考:
Tampermonkey 数据存储之 GM_setValue / GM_getValue - Tampermonkey - 大象笔记

GM.getValue是一个错误的函数名。正确的函数名应该是GM_getValue。GM_getValue是Tampermonkey和Greasemonkey中用于获取存储的值的函数。它是一个同步函数,可以通过指定键名来获取相应的值。例如,可以使用GM_getValue('time')来获取存储的时间值。\[1\] #### 引用[.reference_title] - *1* [Tampermonkey 高级API的使用 附Demo](https://blog.csdn.net/github_35631540/article/details/102719153)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [--介绍/用法](https://blog.csdn.net/feiying0canglang/article/details/114235964)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [实现 全局变量 跨标签页共享变量方法](https://blog.csdn.net/qq_34626094/article/details/113127624)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

滕青山博客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值