时间:2021-05-18
常见的getElementById,getElementsByName,getElementsByTagName。但外国人不满意这些API,于是搞出了getElementsByClassName,后来一点点又出现了jQuery选择器,这里只说原始js选择。
1.getElementById
这是最常用的选择器,通过id来定位:
例:
var test=document.getElementById("test").value;//获取文档中id为test的元素的值,并赋值给test变脸
2.getElementsByName
例:
var test=document.getElementByName("test");//获取文档中name为test的元素的节点,并赋值给test变量,此时test变量是一个数组
3.getElementsByTagName
例:
var test=document.getElementsByTagName("test");//获取文档中class为test的元素的节点,并赋值给test,此时test变量是一个数组 ,这个选择器在IE5,6,7,8中无法使用
4.getElementsByClassName
这个选择器在js的API中是找不到的,想要使用必须自己定义方法,通常的原理为先使用getElementsByTagName("*")取出文档中所有元素,然后进行遍历,使用正则表达式找出匹配的元素放入一个数组返回。网上有很多程序员实现了这个选择器,下面举两例:
(1)The Ultimate getElementsByClassName方案,作者为Robert Nyman,05年实现,可见老外许多东西在很早以前就走得很远了。
复制代码 代码如下:
//三个参数都是必需的,查找一网页中5007个类名为“cell”的元素,IE8历时1828 ~ 1844毫秒,
//IE6为4610 ~ 6109毫秒,FF3.5为46 ~ 48毫秒,opera10为31 ~ 32毫秒,Chrome为23~ 26毫秒,
//safari4为19 ~ 20毫秒
function getElementsByClassName(oElm, strTagName, strClassName){
var arrElements = (strTagName == "*" && oElm.all)? oElm.all :
oElm.getElementsByTagName(strTagName);
var arrReturnElements = new Array();
strClassName = strClassName.replace(/\-/g, "\\-");
var oRegExp = new RegExp("(^|\\s)" + strClassName + "(\\s|$)");
var oElement;
for(var i=0; i < arrElements.length; i++){
oElement = arrElements[i];
if(oRegExp.test(oElement.className)){
arrReturnElements.push(oElement);
}
}
return (arrReturnElements)
}
(2)由Dustin Diaz(《JavaScript Design Patterns》的作者)提供,但兼容性不如上面的,不支持IE5。
复制代码 代码如下:
//后两参数是可靠的,查找一网页中5007个类名为“cell”的元素,IE8历时78毫秒,IE6历时125~171毫秒
//FF3.5为42 ~ 48毫秒,opera10为31 毫秒,Chrome为22~ 25毫秒,safari4为18 ~ 19毫秒
var getElementsByClass = function(searchClass,node,tag) {
var classElements = new Array();
if ( node == null )
node = document;
if ( tag == null )
tag = '*';
var els = node.getElementsByTagName(tag);
var elsLen = els.length;
var pattern = new RegExp("(^|\\s)"+searchClass+"(\\s|$)");
for (i = 0, j = 0; i < elsLen; i++) {
if ( pattern.test(els[i].className) ) {
classElements[j] = els[i];
j++;
}
}
return classElements;
}
--------------------------------------------------------------------------------------------------------------------------------------------------------
注:this可以表示当前元素的节点。
--------------------------------------------------------------------------------------------------------------------------------------------------------
下面是配合事件等知识点的一些常用的使用方法:
复制代码 代码如下:
//提交id为test的表单
document.getElementById("test").submit();
//将id为test元素的边框设置为2个像素,实体,红色
document.getElementById("test").style.border="2px solid red";
//鼠标移动或移出id为test的元素,改变其背景色
function test(){
document.getElementById("test").onmouseover=function(){document.getElementById("test2").style.backgroundColor="red"};
document.getElementById("test").onmouseout=function(){document.getElementById("test2").style.backgroundColor="blue"};
}
//弹出文档中name为test的元素的个数
function test()
{
var test=document.getElementsByName("test");
alert(test.length);
}
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文为大家分享了微信小程序switch开关选择器使用方法,供大家参考,具体内容如下效果图WXML状态:{{isChecked1}}状态:{{isChecked2
怎么使用ipodshuffle音乐播放器使用方法怎么使用ipodshuffle音乐播放器使用方法怎么使用ipodshuffle音乐播放器使用方法怎么使用ipod
jQuery的选择器可谓之强大无比,这里简单地总结一下常用的元素查找方法jQuery选择器使得获得页面元素变得更加容易、更加灵活,从而大大减轻了开发人员的压力。
复制代码代码如下:////使用方法//$(文本域选择器).insertContent("插入的内容");//$(文本域选择器).insertContent("插
CSS3中选择器:nth-child()该怎么使用呢?下面我们就来看看:nth-child()选择器的使用方法。软件名称:AdobeDreamweaverCC2