大家好,欢迎来到IT知识分享网。
mv3 中 popup.js 如何引用其他js的变量或者常量
content.js能直接调用其他js的变量或者常量,但是不能用import from
在 Manifest V3 中,由于扩展的隔离性,直接在不同脚本文件间共享变量或常量不再是一个简单的操作。但是,你可以使用 Chrome 扩展 API 提供的不同机制来实现这一点,例如:
- 使用
chrome.storage
API:可以在 popup 和其他脚本之间同步数据。 - 使用
chrome.runtime
API:通过这个 API 你可以在不同的脚本间传递消息,包括变量值。
以下是使用 chrome.storage
的一个简单例子:
// 存储变量到 chrome.storage
function saveVariableToStorage(name, value) {
chrome.storage.sync.set({ [name]: value }, function() {
console.log('Variable saved.');
});
}
// 从 chrome.storage 获取变量
function getVariableFromStorage(name, callback) {
chrome.storage.sync.get(name, function(result) {
callback(result[name]);
});
}
// 在 popup.js 中使用
document.addEventListener('DOMContentLoaded', function() {
// 假设你想要在 popup 中使用变量 'myVar'
let myVar = 'Hello, Extension!';
// 存储变量
saveVariableToStorage('myVar', myVar);
// 获取变量
getVariableFromStorage('myVar', function(retrievedValue) {
console.log(retrievedValue); // 使用获取到的变量
});
});
在其他脚本中,你可以使用相应的 get
方法来获取这个变量。
请注意,chrome.storage
和 chrome.runtime
需要额外的权限声明,你需要在 manifest.json
中添加相应的权限。
提示:AI自动生成,仅供参考
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/143634.html