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

2021-04-20 12:38:18 +08:00
 maloneleo88
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">');
2534 次点击
所在节点    JavaScript
17 条回复
FEDT
2021-04-20 12:45:17 +08:00
循环里写$(".th-bg:first").eq(i).children
FEDT
2021-04-20 12:46:06 +08:00
@FEDT 漏了 siblings()
maloneleo88
2021-04-20 12:49:12 +08:00
@FEDT eq 是什么意思? 上面已经定义变量 g 了呀, 还要重写?
dallaslu
2021-04-20 13:23:14 +08:00
$('g[i]') 应该写成 $(g[i]) ?
TomatoYuyuko
2021-04-20 13:42:17 +08:00
好久没用 jq 了我没记错的话,children 是个数组,你对他操作一次只能 append 第一个,你想要集体操作需要写个循环。
而且这个思路也不好,加那么多监听,你不如父元素事件委托,然后通过制定元素的 class 判断进行某种操作
twinsdestiny
2021-04-20 13:42:19 +08:00
不是用 g[i]遍历,用 eq(i)遍历
maloneleo88
2021-04-20 13:42:22 +08:00
@dallaslu 不行呀 , 话说怎么不翻墙都上不了论坛了呢
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
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
2021-04-20 13:57:53 +08:00
@TomatoYuyuko 先给每第一个子元素加上类名, 然后给有 class 类名的直接加按钮 是这思路嘛?
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
2021-04-20 14:03:30 +08:00
全部加按钮,按钮共用一个父级的监听事件,参考 js 里的事件委托。
至于你代码的错误是因为“.children("td:first").append(” 行不通,append 只能一个一个来
@maloneleo88
TomatoYuyuko
2021-04-20 14:04:39 +08:00
@TomatoYuyuko 哦我看错了,没看到:first,那就是一个没错
maloneleo88
2021-04-20 15:58:42 +08:00
@twinsdestiny 可以了, 请问为什么要加.eq
twinsdestiny
2021-04-20 16:23:34 +08:00
@maloneleo88
g.eq(i) 其实跟 $(g[i]) 是差不多意思
g 是一个 jquery 对象,要使用 eq 来选择第几个元素,这样选出来的元素能够继续使用 jquery 操作,而不是直接选取数组第几个元素
g[i]是选取了其中第 i 个 dom 对象,不能直接使用 jquery 操作,要想使用 jquery 操作,需要加$(g[i]),是不需要加''分号的,$('g[i]')没有这样用的
maloneleo88
2021-04-20 16:25:03 +08:00
@twinsdestiny 谢谢 学习了 😊
lin07hui
2021-04-21 10:23:12 +08:00

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/771872

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX