label下button的触发问题?

木头是猫 2011-12-06 12:26:40
<label>
<button type="button" id="a" name="a" onclick="alert(1)">11111111111111</button>
<button type="button" id="b" name="b" onclick="alert(2)">22222222222222</button>
<button type="button" id="c" name="c" onclick="alert(3)">33333333333333</button>
</label>


在IE6~8中,点击任意button都可以正常触发

但在IE9/Chrome中,点击b(或c)都会先触发b(或c),接着触发a

在不能去掉label的情况下,如何让触发事件正常化,点b只触发b,而不会触发a
...全文
383 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
峭沙 2011-12-06
  • 打赏
  • 举报
回复
这是因为3个按钮都放在label里面,当你在点击按钮的同时,也点击了label,而label的特性就是被点击的时候,会解发其子元素中的第一个表单元素的点击事件。
	<label onclick="return false;">
<button type="button" id="a" name="a" onclick="alert(1)">11111111111111</button>
<button type="button" id="b" name="b" onclick="alert(2)">22222222222222</button>
<button type="button" id="c" name="c" onclick="alert(3)">33333333333333</button>
</label>
MuBeiBei 2011-12-06
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 qq307023807 的回复:]

为什么for里什么也不写也行 for='asdfasdfasdf'也行
[/Quote]

火狐谷歌如果不写for默认绑定第一个。

所以才有楼主的问题。

加上个页面没有定义的id就行了~·随便写什么都行,只要不跟input的id一样就OK了~·
qq307023807 2011-12-06
  • 打赏
  • 举报
回复
为什么for里什么也不写也行 for='asdfasdfasdf'也行
MuBeiBei 2011-12-06
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 legend1988 的回复:]

学习了。请问这个是事件冒泡才会出现楼主的问题吗?但是采用了一下stopPropagation和cancelBubble也还不行,貌似又说明了这个不是事件冒泡导致的问题?
引用 1 楼 mubeibei 的回复:

HTML code
<label for="noid">
<button type="button" id="a" name="a" onclick="alert(1)">1……
[/Quote]

label有个for属性,可以指定id,来控制~·

具体可以去查查。

这不是冒泡~·

label如果不指定for的话,默认是绑定第一个~·各浏览器处理不一样~·
Legend1988 2011-12-06
  • 打赏
  • 举报
回复
学习了。请问这个是事件冒泡才会出现楼主的问题吗?但是采用了一下stopPropagation和cancelBubble也还不行,貌似又说明了这个不是事件冒泡导致的问题?
[Quote=引用 1 楼 mubeibei 的回复:]

HTML code
<label for="noid">
<button type="button" id="a" name="a" onclick="alert(1)">11111111111111</button>
<button type="button" id="b" name="b" onclick="alert(2)">22222222222222</button>
<button……
[/Quote]
MuBeiBei 2011-12-06
  • 打赏
  • 举报
回复
<label for="noid">
<button type="button" id="a" name="a" onclick="alert(1)">11111111111111</button>
<button type="button" id="b" name="b" onclick="alert(2)">22222222222222</button>
<button type="button" id="c" name="c" onclick="alert(3)">33333333333333</button>
</label>


给label上定义一个for属性,然后里面的值是,页面上没有对应id的控件就行了~·
内容概要:本文围绕基于Basisformer模型的时间序列锂离子电池SOC(State of Charge,荷电状态)预测展开研究,利用PyTorch框架实现深度学习模型的构建与训练。通过将历史充放电数据作为输入,Basisformer能够有效捕捉电池状态的动态变化特征,提升SOC预测精度。文中详细介绍了模型结构设计、数据预处理流程、训练策略及实验结果分析,并与传统方法进行对比,验证了该方法在复杂工况下的优越性与鲁棒性。该研究不仅展示了Basisformer在时序建模中的潜力,也为电池管理系统提供了高精度的状态估计解决方案。; 适合人群:具备一定Python编程基础和深度学习理论知识,熟悉PyTorch框架,从事电池管理系统、新能源汽车或智能预测方向研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于电动汽车、储能系统等领域的电池SOC高精度实时估算;②为电池健康管理(BMS)提供可靠的状态输入;③推动深度学习在时间序列预测中的实际落地,提升现有预测模型的泛化能力与稳定性; 阅读建议:建议读者结合标题为【锂电池SOC估计】【PyTorch】基于Basisformer时间序列锂离子电池SOC预测研究(python代码实现)的资源,重点研读所提供的Python代码,深入理解数据处理方式与模型网络结构的设计思路,尝试调整超参数以观察对预测性能的影响,从而全面掌握Basisformer在时序建模中的优势、适用边界及工程化实现路径。

87,990

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧