label标签使用过程当中遇到的问题

  最近在作东西时候使用到了label标签,因为以前不多使用label标签,因此就遇到一个很奇怪的问题。什么问题呢?下面来看一个效果css

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+没有出现错误,
不是很清楚,若是有对这方面比较了解的朋友请解释下吧。
  这个问题其实挺低级的,把标签名写错了嘛。可是当时本身就没有发现,后来仔细研究了一下才发现这个问题,因此仍是记录一下。
相关文章
相关标签/搜索