IE8下关于querySelectorAll()的问题


Posted in Javascript onMay 13, 2010

当用querySelector()或querySelectorAll()查找类似name="2nd_btn"的元素时,FF,chrome和IE8都会报错。
FF,chrome报的错是一样的,如下所示:
Error: uncaught exception: [Exception... "An invalid or illegal string was specified" code: "12" nsresult: "0x8053000c (NS_ERROR_DOM_SYNTAX_ERR)" location: ".../test/qsa.html Line: 18"]
IE8的报错提示:行: 18 错误: 参数无效。
一寻思,name的值是以数字开头的,把数字去掉或修改后,就能取到了。
这就告诉我们,一般可自定义标签的属性值时,属性值不能以数字开头,也不能包含$,^等不常用的字符。
在HTML页面开始一定要记得声明<!DOCTYPE>。

测试代码:

<!DOCTYPE> 
<html> 
<head></head> 
<body> 
<div id="foo"> 
<a name="warns" href="">This is a sample warning</a> 
<a id="3err" href="">This is a sample error</a> 
</div> 
<div id="bar"> 
<a name="warns" href="">This is another sample warning</a> 
<a name="1err" href="">This is another sample error</a> 
</div> 
<script> 
var a = document.querySelectorAll("[name=warns]") 
alert(a.length)//输出:2 
var b = document.querySelector("[id=3err]") 
alert(b.tagName)//报错 
var c = document.querySelectorAll("[name=1err]") 
alert(c.length)//报错 
</script> 
</body> 
</html>
Javascript 相关文章推荐
firefox中用javascript实现鼠标位置的定位
Jun 17 Javascript
jQuery ajax cache缓存问题
Jul 01 Javascript
Javascript闭包(Closure)详解
May 05 Javascript
jquery+html5时钟特效代码分享(可设置闹钟并且语音提醒)
Mar 30 Javascript
jquery实现滑屏大图定时收缩为小banner图片的广告代码
Sep 02 Javascript
javascript动态添加checkbox复选框的方法
Dec 23 Javascript
一种Javascript解释ajax返回的json的好方法(推荐)
Jun 02 Javascript
Bootstrap3 内联单选和多选框
Dec 29 Javascript
详解浏览器渲染页面过程
Feb 09 Javascript
在iframe中使bootstrap的模态框在父页面弹出问题
Aug 07 Javascript
详解webpack提取第三方库的正确姿势
Dec 22 Javascript
微信小程序自定义单项选择器样式
Jul 25 Javascript
关于可运行代码无法正常执行的使用说明
May 13 #Javascript
jquery validate.js表单验证的基本用法入门
May 13 #Javascript
JQuery 选择器 xpath 语法应用
May 13 #Javascript
bgsound 背景音乐 的一些常用方法及特殊用法小结
May 11 #Javascript
通过判断JavaScript的版本实现执行不同的代码
May 11 #Javascript
JavaScript 判断指定字符串是否为有效数字
May 11 #Javascript
Jquery 获得服务器控件值的方法小结
May 11 #Javascript
You might like
二次元帅气男生排行榜,只想悄悄收藏系列
2020/03/04 日漫
PHP strtr() 函数使用说明
2008/11/21 PHP
PHP 删除文件与文件夹操作 unlink()与rmdir()这两个函数的使用
2011/07/17 PHP
用PHP实现小写金额转换大写金额的代码(精确到分)
2012/01/10 PHP
php对大文件进行读取操作的实现代码
2013/01/23 PHP
教你如何开启shopnc b2b2c 伪静态
2014/10/21 PHP
laravel-admin表单提交隐藏一些数据,回调时获取数据的方法
2019/10/08 PHP
PHP中关于php.ini参数优化详解
2020/02/28 PHP
js面向对象设计用{}好还是function(){}好(构造函数)
2011/10/23 Javascript
用队列模拟jquery的动画算法实例
2015/01/20 Javascript
JavaScript实现下拉列表框数据增加、删除、上下排序的方法
2015/08/11 Javascript
js数组如何添加json数据及js数组与json的区别
2015/10/27 Javascript
js实现拖拽效果(构造函数)
2015/12/14 Javascript
Vue2.0 组件传值通讯的示例代码
2017/08/01 Javascript
Vue.js项目实战之多语种网站的功能实现(租车)
2019/08/07 Javascript
vue解决花括号数据绑定不成功的问题
2019/10/30 Javascript
vue组件中传值EventBus的使用及注意事项说明
2020/11/16 Javascript
[56:56]VG vs LGD 2019国际邀请赛淘汰赛 胜者组 BO3 第一场 8.22
2019/09/05 DOTA
Python实现过滤单个Android程序日志脚本分享
2015/01/16 Python
python获取mp3文件信息的方法
2015/06/15 Python
python简单实现基于SSL的IRC bot实例
2015/06/15 Python
widows下安装pycurl并利用pycurl请求https地址的方法
2018/10/15 Python
Python开发之Nginx+uWSGI+virtualenv多项目部署教程
2019/05/13 Python
python实现实时视频流播放代码实例
2020/01/11 Python
pycharm无法导入本地模块的解决方式
2020/02/12 Python
python import 上级目录的导入
2020/11/03 Python
解决python3中os.popen()出错的问题
2020/11/19 Python
John Varvatos官方网站:设计师男士时装
2017/02/08 全球购物
南京软件公司的.net程序员笔试题
2014/08/31 面试题
药学专业学生的自我评价分享
2014/02/06 职场文书
租房协议书
2014/04/10 职场文书
2014年煤矿工作总结
2014/11/24 职场文书
幼儿园教师教育随笔
2015/08/14 职场文书
Python进阶学习之带你探寻Python类的鼻祖-元类
2021/05/08 Python
MySQL中的引号和反引号的区别与用法详解
2021/10/24 MySQL
Linux中如何安装并部署Redis
2022/04/18 Servers