jQuery元素选择器遍历时的this

html文件里有以下几条复选框数据

<li><label><input type="checkbox" name="fns" value="item1">item1</label></li>
<li><label><input type="checkbox" name="fns" value="item2">item2</label></li>

在控制台输出选择的项内容,可以这样用:

$("input[name=fns]").each((i,d)=>{ if (d.checked) { console.log(d.value) } });

取的是input元素里的value值
也可以这样用

$("input[name=fns]").each(function(){ if (this.checked) { console.log($(this).parent().parent().text()) } });

取的是label标签里的text内容
由于label标签是给人看的,总得有,input里的value则可以不存在,所以html文件这段还可以简化如下:

<li><label><input type="checkbox" name="fns">item1</label></li>
<li><label><input type="checkbox" name="fns">item2</label></li>

有几个要点需要注意下:
1 each()里用this的话,得用function(){}这种形式定义,不能用箭头函数()=>{},因为箭头函数里this不是当前元素,可能是window对象。
2 this是html对象,可以取它的属性值,比如checkbox的checked属性,value属性。
3 $(this)是jquery对象,可以反复应用元素选择器定位到指定元素

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值