V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
iyaozhen
V2EX  ›  问与答

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

  •  1
     
  •   iyaozhen · 2015-03-26 14:26:01 +08:00 · 5329 次点击
    这是一个创建于 3531 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    但原本的页面在提交时偶尔会报错弹窗(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("提交按钮选择出错");
    }
    }

    10 条回复    2015-03-28 11:39:47 +08:00
    bigdude
        1
    bigdude  
       2015-03-26 15:48:23 +08:00
    window.alert = function(){};

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

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

    与嵌入的页面通信
    尽管content script的执行环境与所在的页面是隔离的,但它们还是共享了页面的DOM。 如果页面需要与content script通信(或者通过content script与扩展通信), 就必须通过这个共享的DOM。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2774 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 07:50 · PVG 15:50 · LAX 23:50 · JFK 02:50
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.