这是一个简单的页面:
Meta charset="UTF-8">
我想写一个Chrome扩展程序以防止执行底部脚本(foo(2)).
我尝试编写一个内容脚本,删除最后一个脚本标记:
document.body.removeChild(document.body.lastChild);
但它不起作用.
我想这可能是因为内容脚本在最后一个脚本行执行后运行.然后我尝试将run_at设置为document_start或document_end,但它们都不适合我.
最佳答案
在开发Don’t track me Google用户脚本/扩展时,我遇到了同样的问题.
原文链接:https://www.f2er.com/js/429534.htmlImportant note
The
window
object in a Chrome contentscript cannot be accessed directly,in any way.
I have tested many methods,and the only reliable method is injecting the code through a dynamically created script tag. Have a look at 07001,or my extension’s 07002 for more information.
我使用Object.defineProperty
解决了它.使用此方法,您可以定义属性,并指定有关getter,setter和属性描述符的信息.在你的情况下:
Object.defineProperty(window,'foo',{
value: function(){/*This function cannot be overridden*/}
});
或者,如果要捕获变量,稍后再使用它:
(function() {
var originalFoo = function(){/*Default*/};
Object.defineProperty(window,{
get: function(){
if (confirm('function logic')) return function(){/*dummy*/};
else return originalFoo;
},set: function(fn){originalFoo = fn;}
});
})();
Chrome 17 Bug #115452 Fixed!中的错误
在Chrome 17中,使用V8 3.7.12.12(但不是在Chrome 16中,使用V8 3.6.6.19),函数声明会覆盖属性描述符.
见http://jsfiddle.net/bHUag/
请注意,当函数声明和属性描述符方法位于同一个块中时,似乎不会应用此错误.但这是错误的.效果不可见,因为函数声明总是在代码块之前计算.因此,首先计算函数foo(){},然后计算代码的其余部分.