20、开发chrome插件的一些问题

本文探讨了在Chrome92版本中遇到的JavaScript相关问题,包括:JS引入类型识别错误、事件绑定失效、JS引入位置影响、chrome.tabs.executeScript的文件路径问题、异步处理及本地存储使用。解决方案包括修改JS引入类型、使用DOM操作添加事件监听器、将JS放在body内、指定完整文件路径以及注意异步回调。此外,还提到了chrome.storage的使用情况。

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

一、js引入问题

<script type="application/javascript" src="jquery-1.8.3.js"></script>

在chrome 92版本,使用上述方式引入,会报无法识别$变量错误

需要将引入type改变为text/javascript后,可以使用$变量引用

 <script type="text/javascript" src="jquery-1.8.3.js"></script>

二、事件问题

在给popup.html中的元素添加事件,发现事件没生效,改为js添加事件后正常触发

popup.js

document.getElementById("start").addEventListener('click',function (){
    var bg = chrome.extension.getBackgroundPage();
    bg.Test()
})

三、js引入位置问题

js放在head标签下引入,发现js没有生效,改为body标签内引入,js正常使用

<body>
<script type="text/javascript" src="jquery-1.8.3.js"></script>
<script type="text/javascript" src="js/popup.js"></script>
</body>

四、chrome.tabs.executeScript方法中file路径问题

excute.js和background.js都在js目录下,使用未生效

chrome.tabs.executeScript(tabs[0].id,{file:'excute.js'})

改为如下,正常执行 

chrome.tabs.executeScript(tabs[0].id,{file:'js/excute.js'})

五、异步问题

在使用如下代码,返回tabId后,在popup.js中调用,发现并没有正确输出tabId,原因就是忽略了function(tabs)回调函数的异步问题

chrome.tabs.query({active: true, currentWindow: true}, function(tabs)

六、本地存储问题

 在popup.js中使用chrome.storage的api进行数据存储,并不能在tab页面的application面板下的localstorage中看到对应的数据,也不能在拓展的localstorage中看到。

直接在popup.js中使用,在内容脚本中获取即可

popup.js

chrome.storage.sync.set({'tag': tagArray}, function() {
            console.log('success!');
        });

动态注入excute.js

chrome.storage.sync.get(['tag', 'id', 'class'], function (items) {
    filter(items.tag, items.id, items.class)
})

完整代码

https://github.com/wxwcd/del_elementshttps://github.com/wxwcd/del_elements

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值