label标签使用过程中遇到的问题分析及解决思路
来源: 阅读:1798 次 日期:2016-06-21 11:43:08
温馨提示: 小编为您整理了“label标签使用过程中遇到的问题分析及解决思路”,方便广大网友查阅!

由于之前很少使用label标签,所以今天就遇到一个很奇怪的问题:使用的是IE6, 7, 8这时候发现页面没有提示出来信息,具体的分析思路及解决方法如下,感兴趣的朋友可以参考下,希望对大家有所帮助

最近在做东西时候使用到了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">密&nbsp;&nbsp;码:</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+没有出现错误,不是很清楚,如果有对这方面比较了解的朋友请解释下吧。 

这个问题其实挺低级的,把标签名写错了嘛。但是当时自己就没有发现,后来仔细研究了一下才发现这个问题,所以还是记录一下。

更多信息请查看网页制作
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map