为了账号安全,请及时绑定邮箱和手机立即绑定

label直接包裹标标签获得焦点的问题

label直接包裹标标签获得焦点的问题

爱吃芒果 2016-07-10 19:47:06
  <label>慢跑   <input type="checkbox" name="jog" id="1" /></label>   <br>   <label>登山   <input type="checkbox" name="climb" id="2" /></label>   <br>   <label>篮球   <input type="checkbox" name="basketball" id="3" /></label>  <label>慢跑   <input type="checkbox" name="jog" id="1" /><br>   登山   <input type="checkbox" name="climb" id="2" /><br>   篮球   <input type="checkbox" name="basketball" id="3" />   </label>对比上面的两段代码,为什么不可以用一个label标签将三个input标签全部包裹用三个label标签分别包裹三个input标签却可以?
查看完整描述

6 回答

已采纳
?
霸气的擎宇

TA贡献6条经验 获得超5个赞

其实你不用label也是可以的,你要搞清楚为什么用label呢?

或者这样说,你最先要清楚的应该是label标签的作用是什么!

你也知道是获得焦点,但愿你懂究竟什么焦点。就是这个选项本来必须点那个圈才能选中,现在是直接点在这个选项所在的位置,比如文字都可以直接选中这个标签。

那很明显的就是,label让“必须是这个input所在的位置”的任意地方被点击都可以凝聚一个焦点区选中它。

如果多个input 公用一个LABEL  获得焦点之后凝聚在谁身上?总不能全部选中吧?所以规范就是,只能凝聚一个焦点。那么你先用当然就必须每个单独使用了

你的提问其实很有创意,但是可惜的是,规范并没有如你所想的规定符合你想法的标签。而是规定了一个一对一使用的label。你可以联想一下ul   li  为什么li必须一个对应一个而不能一个li包裹所有。label 亦是如此!

查看完整回答
2 反对 回复 2016-07-15
?
业余奶茶品鉴师

TA贡献260条经验 获得超388个赞

label标签包裹input标签,是为了在点击label标签时,里面包裹的input标签可以获得焦点,是一一对应的。所以三个input标签要分别用三个label标签来包裹。

查看完整回答
4 反对 回复 2016-07-10
?
blovetu

TA贡献319条经验 获得超234个赞

一个label只可以获得一个焦点

查看完整回答
反对 回复 2016-07-11
?
nickylau82

TA贡献128条经验 获得超67个赞

现在已经不用包裹来获得焦点了,都是在for标签中增加for属性来设置。

查看完整回答
反对 回复 2016-07-11
?
php_go

TA贡献16条经验 获得超24个赞

你可以设置label的display为block

查看完整回答
反对 回复 2016-07-10
  • 6 回答
  • 0 关注
  • 2547 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信