今天小编跟大家讲解下有关label标签使用过程中遇到的问题分析及解决思路 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关label标签使用过程中遇到的问题分析及解决思路 的相关资料,希望小伙伴们看了有所帮助。
最近在做东西时候使用到了label标签 由于之前很少使用label标签 所以就遇到一个很奇怪的问题。什么问题呢 下面来看一个效果 <!DOCTYPE html> <html> <head> <meta charset="utf-8"/> <title>HTML label tag 学习 by Typeof</title> <style type="text/css"> html, body { margin: 0; padding: 0; } .title { margin: 10px; } .login-item, .login-button { margin: 20px; height: 30px; } .clearfix { clear: both; content:""; display: block; } .login-item label { float: left; width: 70px; } .login-item .text { height: 18px; width: 200px; float: left; } </style> </head> <body> <div class="title"> label标签使用过程中遇到的问题 </div> <div class="login-item clearfix"> <label for="username">用户名:</label> <input type="text"class="text"id="username"name="username"/> <lable id="J_usernameError"></label> </div> <div class="login-item clearfix"> <label for="password">密 码:</label> <input type="text"class="text"id="password"name="username"/> <label id="J_passwordError"></label> </div> <div class="login-button clearfix"> <input type="submit"value="登录"id="J_submitLogin"/> </div> <script> document.getElementById('J_submitLogin').onclick = function() { var usernameError = document.getElementById('J_usernameError'); usernameError.innerHTML = '用户名错误'; }; </script> </body> </html> 提示:您可以先修改部分代码再运行这个demo要实现的目的是在点击登录按钮的时候校验用户输入的用户名、密码是否合法 如果不合法就在用户名输入框下面提示错误信息。 提示错误信息的元素计划用label实现。 通过运行代码打开demo页面 点击登录按钮 看会有什么变化。如果使用的是Firefox、Chrome或者IE9+ 则点击登录按钮之后会提示 “用户名错误” 这是想要的结果。如果使用的是IE6, 7, 8如何一个再看看会有什么变化呢 这时候发现页面没有提示出来信息 打开开发人员工具 看下控制这时候会发现提示出来错误信息“script600: 未知的运行时错误 ”。遇到这个问题的时候尝试了innerText和innerHTML两种方法 发现都会报这样的错误 以为是使用方法不对去w3cschool上面查了下发现也没有说不支持innerText和innerHTML的。 到底为什么会在IE6, 7, 8提示这样的错误而Firefox, Chrome, IE9+(其他浏览器没有尝试)运行正常呢。细心的人可能一下就看出问题在哪里了 对于提示“用户名错误”的元素开始标签写成了“lable”而不是label。但是我当时就没有发现这问题 一直以为是label标签使用方式上出现了问题呢 至于为什么IE6, 7, 8的JS引擎会在操作这种把标签名写错的元素的innerText、innerHTMl属性时出现错误 而Firefox、Chrome和IE9+没有出现错误 不是很清楚 如果有对这方面比较了解的朋友请解释下吧。 这个问题其实挺低级的 把标签名写错了嘛。但是当时自己就没有发现 后来仔细研究了一下才发现这个问题 所以还是记录一下。来源:爱蒂网