V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
yulihao
V2EX  ›  程序员

求助如何使用 js 脚本(或油猴脚本)点击 class 按钮

  •  
  •   yulihao · 2020-08-07 10:04:40 +08:00 · 2951 次点击
    这是一个创建于 1597 天前的主题,其中的信息可能已经有所发展或是发生改变。
    按钮代码如下
    <div class="click-area"></div>
    <div class="option-item first-option">A</div>
    要求是当按钮出现时实现自动点击,谢谢啦
    第 1 条附言  ·  2020-08-10 21:56:48 +08:00
    #11 楼
    正解
    no1xsyzy
        1
    no1xsyzy  
       2020-08-07 10:06:13 +08:00   ❤️ 1
    当按钮出现时?
    那只有 MutationObserver 了
    yulihao
        2
    yulihao  
    OP
       2020-08-07 10:12:24 +08:00
    @no1xsyzy 有具体代码吗,写第二个按钮就行
    no1xsyzy
        3
    no1xsyzy  
       2020-08-07 10:16:31 +08:00
    @yulihao #2 伸手还是退避吧
    yulihao
        4
    yulihao  
    OP
       2020-08-07 10:23:02 +08:00
    @no1xsyzy 我主要是百度和谷歌了一堆代码(自己也学过来改),挂在油猴里面无效,各种报错
    ochatokori
        6
    ochatokori  
       2020-08-07 10:33:59 +08:00 via Android
    类选择器
    kuro1
        7
    kuro1  
       2020-08-07 10:34:30 +08:00
    $("body").bind('DOMNodeInserted', function(e)
    wlor
        8
    wlor  
       2020-08-07 10:42:18 +08:00
    $("body").bind('DOMNodeInserted', (e) =>{
    if ($(e.target).attr("class") === "option-item first-option") {
    $(e.target).click()
    $('body').unbind("DOMNodeInserted");
    }
    });
    no1xsyzy
        9
    no1xsyzy  
       2020-08-07 11:16:09 +08:00   ❤️ 1
    @kuro1 #7 @wlor #8 提醒一下吧
    Note: Mutation Events (W3C DOM Level 3 Events) have been deprecated in favor of Mutation Observers (W3C DOM4).
    顺便 bind / unbind 也 deprecated 了(被 on / off 取代)。
    如果不在乎 deprecated 的话有比 #8 更好的写法。
    提示:1. jquery on 事件代理机制; 2. 为 function 添加名称来在内部使用之。
    wlor
        10
    wlor  
       2020-08-07 11:34:39 +08:00
    好的 学习了
    pluszone
        11
    pluszone  
       2020-08-07 14:39:39 +08:00
    document.querySelector('#xxxxxxx').click();
    可以用 setTimeout 写个延时
    yulihao
        12
    yulihao  
    OP
       2020-08-10 21:56:39 +08:00
    #11 楼
    正解
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2934 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 08:22 · PVG 16:22 · LAX 00:22 · JFK 03:22
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.