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

一、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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值