Chrome扩展修改页面代码执行环境的方法

本文详细介绍了如何通过Chrome扩展程序的contentscripts功能,向页面中注入JavaScript代码,进而修改页面代码执行环境的方法。包括两种实现方式:通过在DOM对象上添加事件处理器并触发,或在文档中插入script元素直接执行代码。

Chrome的扩展程序可以通过content scripts向页面中注入js代码,所注入的js代码能够对页面中所有的DOM对象进行操作。由于Chrome在js执行环境上对页面代码和content scripts代码进行了隔离,所以,在content scripts中,无法直接修改页面代码执行环境。不过我们还是可以通过一些技巧向页面代码执行环境中插入想要执行的js代码段,从而能够修改页面代码的执行环境。

第一种方法,通过在DOM对象上添加一个event handler,然后派发对应的event给该DOM对象,触发调用添加的event handler。该event handler的回调发生在页面代码执行环境中,可以趁机对页面代码执行环境进行修改。具体代码可以参考stackoverflow.com中的一个问答:(http://stackoverflow.com/questions/23202136/changing-navigator-useragent-using-chrome-extension)。

第二种方法,可以通过在document里面插入一个script element,script元素里面的代码可以直接在页面代码执行环境中执行。同样的,该代码段也可以对页面代码执行环境进行修改。该方法的demo可以参考(https://github.com/ratzhou/tomato)。

 

转载于:https://www.cnblogs.com/ratzhou/p/4830104.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值