Chrome 扩展如何屏蔽(绕过)页面的弹窗( alert)

2015-03-26 14:26:01 +08:00
 iyaozhen

我有一个扩展实现的很简单功能,就是点击页面上的一个选择按钮,然后再点击提交按钮。

但原本的页面在提交时偶尔会报错弹窗(alert),然后就会阻塞js的执行(我需要刷新页面再执行上述相同的操作)。

核心代码:

var button = $("button")[0];
var submit = $("button")[1];
if ($(button).data('bind') == "hooked_btn:fast_remove") {
button.click();
}
else{
console.log("筛选按钮选择出错");
}
var list = $(".glyphicon-chevron-left").length;
if(list > 0){
if ($(submit).data('bind') == "click:confirm_remove") {
submit.click();
setTimeout(function(){
location.reload();
}, 200);
}
else{
console.log("提交按钮选择出错");
}
}

5191 次点击
所在节点    问与答
10 条回复
bigdude
2015-03-26 15:48:23 +08:00
window.alert = function(){};

覆盖掉原方法
lmaq
2015-03-26 18:01:43 +08:00
顶楼上~
iyaozhen
2015-03-27 11:56:43 +08:00
@bigdude 这个方法我知道,但不行,chrome 扩展的 js 环境和页面 js 环境是隔离的。
@lmaq
lmaq
2015-03-27 12:55:47 +08:00
@iyaozhen 不要把脚本写到background,chrome扩展使用content_scripts
iyaozhen
2015-03-27 13:41:12 +08:00
@lmaq 是 content_scripts,不行。难道是我姿势不对,我再试试
lmaq
2015-03-27 14:30:35 +08:00
@iyaozhen 我这测试没有问题啊
iyaozhen
2015-03-27 15:08:02 +08:00
iyaozhen
2015-03-27 15:09:05 +08:00
lmaq
2015-03-28 10:38:59 +08:00
两个 content_scripts
控制content script注入的时机。可以是document_start, document_end或者document_idle

第一个 content_scripts 先载入 alert
第二个再载入你要的代码
iyaozhen
2015-03-28 11:39:47 +08:00
@lmaq 还是不行。找到一些说明:
当然,content scripts也有一些限制,它们不能做的事情包括 :
不能访问web页面或其它content script中定义的函数和变量

与嵌入的页面通信
尽管content script的执行环境与所在的页面是隔离的,但它们还是共享了页面的DOM。 如果页面需要与content script通信(或者通过content script与扩展通信), 就必须通过这个共享的DOM。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/179496

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX