pu369com

最简单的Chrome扩展插件V3版本

单位升级了OA办公系统,有一个必填项,通常写“同意”,然而系统设计不合理,需要打字或点好几次鼠标才行。自己写个chrome extension来填写吧。

在任意目录中,建立2个文件:manifest.json和content.js

1、manifest.json

复制代码
{
  "version": "0.0.1",
  "name": "Test",
  "description": "Test",
  "host_permissions": ["*://*/*"],
  "content_scripts": [
    {
      "js": ["content.js"],
      "matches": ["*://192.168.1.2/*"]      
    }
  ],
  "manifest_version": 3
}
复制代码
192.168.1.2/*匹配OA办公系统网址,其它没什么可解释的

2、content.js

复制代码
//延时1秒,保证页面动态加载的元素都加载完
setTimeout("fireContentLoadedEvent ()", 1000)
function fireContentLoadedEvent () {
console.log (window.location.href);
try{
el_1=document.querySelector("#div > div.wf > span.si");
el_1.innerText="同意";
ifr = document.querySelector("#cks > iframe");
ifr.contentDocument.querySelector("body > p").innerText="同意";
}catch(e){}
};
复制代码

本来想在DOMContentLoaded事件后执行,总有问题,怀疑是因为页面内容是延迟动态加载,而且还有iframe,于是干脆暴力等1秒后再操作DOM,效果不错

小技巧之一:在chrome中按Ctrl + Shit +J  ,在 元素 中找到要操作的网页元素,在元素上 鼠标右键-复制-复制js路径,得到类似document.querySelector(" span")的元素,然后粘贴到控制台中先测试一下,如:document.querySelector(" span").click()

小技巧之二:对于iframe一直头痛,但js操作也不难,如上面的代码,先用 document.querySelector取到ifame元素 , 再用.contentDocument.querySelector取iframe中的元素

最后就是,点chrome右上方的三个点-更多工具-扩展程序   ,打开 开发者模式  加载已解压的扩展程序 找到上述两个文件所在目录加载。加载后可以关闭 开发者模式

然后工作时就可以稍微省点事了。

 

 

posted on   pu369com  阅读(1186)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示