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

[求助] 这段代码错在哪里了?

  •  
  •   maloneleo88 · 2021-04-20 12:38:18 +08:00 · 2357 次点击
    这是一个创建于 1073 天前的主题,其中的信息可能已经有所发展或是发生改变。
    g = $(".th-bg:first").siblings();
    for (var i = 0; i< g.length; i ++)
    {$('g[i]').children("td:first").append('<input type="button" value="BTTS">')};

    我想给 th-bg 所有兄弟标签的第一个子标签增加一个按钮事件。 这里哪里写错了呀?


    下面这样是可以的,但是只能增加第一个,为什么?? 求解
    $(".th-bg:first").siblings().children("td:first").append('<input type="button" value="BTTS">');
    17 条回复    2021-04-21 10:23:12 +08:00
    FEDT
        1
    FEDT  
       2021-04-20 12:45:17 +08:00 via iPhone
    循环里写$(".th-bg:first").eq(i).children
    FEDT
        2
    FEDT  
       2021-04-20 12:46:06 +08:00 via iPhone
    @FEDT 漏了 siblings()
    maloneleo88
        3
    maloneleo88  
    OP
       2021-04-20 12:49:12 +08:00
    @FEDT eq 是什么意思? 上面已经定义变量 g 了呀, 还要重写?
    dallaslu
        4
    dallaslu  
       2021-04-20 13:23:14 +08:00
    $('g[i]') 应该写成 $(g[i]) ?
    TomatoYuyuko
        5
    TomatoYuyuko  
       2021-04-20 13:42:17 +08:00
    好久没用 jq 了我没记错的话,children 是个数组,你对他操作一次只能 append 第一个,你想要集体操作需要写个循环。
    而且这个思路也不好,加那么多监听,你不如父元素事件委托,然后通过制定元素的 class 判断进行某种操作
    twinsdestiny
        6
    twinsdestiny  
       2021-04-20 13:42:19 +08:00
    不是用 g[i]遍历,用 eq(i)遍历
    maloneleo88
        7
    maloneleo88  
    OP
       2021-04-20 13:42:22 +08:00
    @dallaslu 不行呀 , 话说怎么不翻墙都上不了论坛了呢
    TomatoYuyuko
        8
    TomatoYuyuko  
       2021-04-20 13:44:58 +08:00
    // todo 对$('g[i]').children("td:first")循环添加 class"first"
    $($('g[i]')).on(
    // todo ....
    if(e.target.class.includes('first')){

    }

    )
    maloneleo88
        9
    maloneleo88  
    OP
       2021-04-20 13:47:52 +08:00
    @twinsdestiny 彻底蒙圈

    for (var i = 0; i< g.length; i ++)
    {$(".th-bg:first").siblings().eq(i).children("td:first").append(\'<input type="button" value="BTTS">\')};

    ??
    maloneleo88
        10
    maloneleo88  
    OP
       2021-04-20 13:57:53 +08:00
    @TomatoYuyuko 先给每第一个子元素加上类名, 然后给有 class 类名的直接加按钮 是这思路嘛?
    twinsdestiny
        11
    twinsdestiny  
       2021-04-20 14:00:46 +08:00
    @maloneleo88
    var g = $(".th-bg:first").siblings();
    for (var i = 0; i < g.length; i++)
    {
    g.eq(i).children("td:first").append('<input type="button" value="BTTS">')
    };
    TomatoYuyuko
        12
    TomatoYuyuko  
       2021-04-20 14:03:30 +08:00
    全部加按钮,按钮共用一个父级的监听事件,参考 js 里的事件委托。
    至于你代码的错误是因为“.children("td:first").append(” 行不通,append 只能一个一个来
    @maloneleo88
    TomatoYuyuko
        13
    TomatoYuyuko  
       2021-04-20 14:04:39 +08:00
    @TomatoYuyuko 哦我看错了,没看到:first,那就是一个没错
    maloneleo88
        14
    maloneleo88  
    OP
       2021-04-20 15:58:42 +08:00
    @twinsdestiny 可以了, 请问为什么要加.eq
    twinsdestiny
        15
    twinsdestiny  
       2021-04-20 16:23:34 +08:00   ❤️ 3
    @maloneleo88
    g.eq(i) 其实跟 $(g[i]) 是差不多意思
    g 是一个 jquery 对象,要使用 eq 来选择第几个元素,这样选出来的元素能够继续使用 jquery 操作,而不是直接选取数组第几个元素
    g[i]是选取了其中第 i 个 dom 对象,不能直接使用 jquery 操作,要想使用 jquery 操作,需要加$(g[i]),是不需要加''分号的,$('g[i]')没有这样用的
    maloneleo88
        16
    maloneleo88  
    OP
       2021-04-20 16:25:03 +08:00 via Android
    @twinsdestiny 谢谢 学习了 😊
    lin07hui
        17
    lin07hui  
       2021-04-21 10:23:12 +08:00
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2855 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 15:22 · PVG 23:22 · LAX 08:22 · JFK 11:22
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.