V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
wallriding
V2EX  ›  JavaScript

能否监听类似于“某个 selector 指向的元素已生成”的事件?

  •  
  •   wallriding · 2019-09-15 01:10:53 +08:00 · 3411 次点击
    这是一个创建于 1676 天前的主题,其中的信息可能已经有所发展或是发生改变。

    现有一个网页(非我控制的),点击某个按钮之后会生成一个 form,我现在想通过 greasemonkey 脚本去给这个 form 里的<div id="existingForm">后面加一个<div id="newForm">

    我的想法是在这个按钮的 click 事件回调函数里,用$("#existingForm")找到这个元素,然后添加。但是我发现找不到这个元素,我猜测原因是点击按钮之后这个 existingForm 需要一小段时间才能生成,而我检测是否有这个元素的代码先于添加这个元素的代码执行了。于是我加上了 setTimeout,就能顺利找到元素了。

    我的问题是除了这个用 setTimeout 暴力轮询的放法以外,还有别的方法吗?我理想中的状态是,在 existingForm 在网页上出现之后,立即执行某段代码。

    先感谢愿意帮忙的朋友了

    7 条回复    2019-09-15 16:28:48 +08:00
    mskf
        1
    mskf  
       2019-09-15 03:01:08 +08:00
    监听父节点的子节点变动事件?
    azh7138m
        3
    azh7138m  
       2019-09-15 03:26:58 +08:00 via Android
    zhengjian
        4
    zhengjian  
       2019-09-15 05:05:02 +08:00
    聊聊 JS DOM 变化的监听检测与应用 ——张鑫旭
    https://www.zhangxinxu.com/wordpress/2019/08/js-dom-mutation-observer/
    autoxbc
        5
    autoxbc  
       2019-09-15 10:11:32 +08:00
    belin520
        6
    belin520  
       2019-09-15 10:28:36 +08:00 via iPhone
    事件代理?
    jinliming2
        7
    jinliming2  
       2019-09-15 16:28:48 +08:00 via iPhone
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1194 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 23:11 · PVG 07:11 · LAX 16:11 · JFK 19:11
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.