0

0

如何在 Tampermonkey 中可靠地向动态渲染页面注入按钮元素

碧海醫心

碧海醫心

发布时间:2026-03-17 10:13:06

|

195人浏览过

|

来源于php中文网

原创

如何在 Tampermonkey 中可靠地向动态渲染页面注入按钮元素

本文详解为何脚本在 Chrome 控制台中正常运行却在 Tampermonkey 中失效,并提供基于 MutationObserver 的健壮解决方案,避免轮询与硬编码延迟,确保 DOM 元素就绪后精准插入自定义按钮。

本文详解为何脚本在 chrome 控制台中正常运行却在 tampermonkey 中失效,并提供基于 `mutationobserver` 的健壮解决方案,避免轮询与硬编码延迟,确保 dom 元素就绪后精准插入自定义按钮。

在 Tampermonkey 中编写 DOM 操作脚本时,一个常见误区是假设 @run-at document-body 能保证目标元素已存在——但事实并非如此。尤其在使用 React、Vue 或 AJAX 渲染的现代 Web 应用(如 Snipe-IT)中,#create-form 等关键结构往往由 JavaScript 异步生成,远晚于 <body> 解析完成。因此,即使设置了 @run-at document-body,document.querySelector(...) 仍可能返回 null,导致后续 appendChild() 失败,按钮完全不出现。

你最初尝试的 setTimeout 延迟方案(如 5000ms)虽能临时“凑效”,但存在严重缺陷:

  • 不可靠:网络波动或设备性能变化可能导致延迟不足或过度;
  • 低效:强制等待固定时长,浪费资源且影响用户体验;
  • 难维护:需反复调试 myDelay 值,无法适配不同环境。

✅ 推荐采用 MutationObserver ——这是浏览器原生提供的异步 DOM 变更监听机制,可精准捕获目标容器的插入时机,实现“元素一出现,立即操作”。

以下是优化后的完整 Tampermonkey 脚本(已修复原始逻辑错误,如 onclick 中误将 appendChild 写在 alert 后导致按钮未被添加):

AI改图神器
AI改图神器

AI万能图片编辑器,一键抠图,去水印,智能图片美化,照片转漫画,照片变活转视频,图片无损放大,一键背景虚化,位图智能转矢量图

下载
// ==UserScript==
// @name         SNIPEIT OFFICE BUTTONS
// @namespace    http://tampermonkey.net/
// @version      0.2
// @description  在 Snipe-IT 表单中可靠注入 Office 版本按钮
// @author       You
// @match        *://your-snipeit-domain.com/*  // ← 替换为实际 URL
// @grant        none
// @run-at       document-idle
// ==/UserScript==

(function() {
    'use strict';

    // 定义目标选择器(建议简化以提升鲁棒性)
    const targetSelector = '#create-form > div > div.box-body > div > div:nth-child(10) > div';

    // 创建两个按钮
    const btn2013 = document.createElement('button');
    btn2013.textContent = 'Office 2013 TM';
    btn2013.style.marginRight = '8px'; // 可选:改善视觉间距
    btn2013.addEventListener('click', () => alert('Office 2013 selected'));

    const btn2019 = document.createElement('button');
    btn2019.textContent = 'Office 2019 TM';
    btn2019.addEventListener('click', () => alert('Office 2019 selected'));

    // 观察器配置:监听子节点添加
    const observer = new MutationObserver((mutations) => {
        for (const mutation of mutations) {
            if (mutation.type === 'childList') {
                const notes = document.querySelector(targetSelector);
                if (notes && !notes.querySelector('button[title="Office 2013 TM"], button[title="Office 2019 TM"]')) {
                    // 避免重复插入(重要!)
                    btn2013.title = 'Office 2013 TM';
                    btn2019.title = 'Office 2019 TM';
                    notes.appendChild(btn2013);
                    notes.appendChild(btn2019);
                    observer.disconnect(); // 任务完成,停止监听
                    return;
                }
            }
        }
    });

    // 启动观察器:监听 <body> 及其后代的 DOM 变化
    observer.observe(document.body, {
        childList: true,
        subtree: true
    });

    // 补充兜底:若 10 秒内仍未找到,主动尝试一次(防极端情况)
    setTimeout(() => {
        if (observer.takeRecords().length === 0) {
            const notes = document.querySelector(targetSelector);
            if (notes && !notes.querySelector('button[title]')) {
                notes.appendChild(btn2013);
                notes.appendChild(btn2019);
            }
        }
    }, 10000);
})();

关键改进说明:

  • ✅ 使用 @run-at document-idle(优于 document-body),确保脚本在页面空闲时执行,更利于观察器初始化;
  • ✅ MutationObserver 主动监听 DOM 变化,而非被动等待,响应及时且零冗余;
  • ✅ 添加 title 属性并检查是否存在,防止按钮被重复插入;
  • ✅ 简化 CSS 选择器风险:若 nth-child(10) 易变动,建议改用语义化 class(如 .field-notes)或结合 data-* 属性定位;
  • ✅ 提供 10s 兜底逻辑,兼顾极少数观察器未触发的边界场景。

调试建议:

  • 在 Tampermonkey 编辑器中启用「显示控制台日志」,在脚本中添加 console.log('Observer active') 验证初始化;
  • 使用 DevTools 的 Elements → 右键目标节点 → Break on → subtree modifications,直观验证元素何时被创建;
  • 将 targetSelector 复制到控制台执行 document.querySelector(...),确认其在页面加载完成后的有效性。

通过 MutationObserver,你不再与时间赛跑,而是真正与 DOM 生命周期协同工作——这才是生产环境脚本应有的健壮性。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

166

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

170

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

124

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

260

2024.09.24

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1083

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

852

2023.11.06

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

255

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1153

2024.03.01

Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建
Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建

本指南详解Nginx在Windows、macOS及Linux系统的安装全流程。涵盖官方包解压、Homebrew一键部署、APT/YUM源配置及Docker容器化方案。无论新手或开发者,均可快速搭建运行环境,掌握跨平台核心指令,为后续配置与调优奠定坚实基础。

10

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号