首页 > 代码库 > 【JS学习笔记】DOM元素灵活查找
【JS学习笔记】DOM元素灵活查找
用className选择元素
(1)如何用className选择元素
选出所有元素
通过className条件筛选
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>用className来选取元素</title>
<style>
</style>
<script>
window.onload = function ()
{
var oUl=document.getElementById(‘ul1‘);
var aLi=oUl.getElementsByTagName(‘li‘);
for(var i=0;i<aLi.length;i++)
{
if(aLi[i].className==‘box‘)
{
aLi[i].style.background=‘red‘;
}
}
};
</script>
</head>
<body>
<ul id="ul1">
<li class="box"></li>
<li class="box"></li>
<li></li>
<li></li>
<li></li>
<li class="box"></li>
<li></li>
</ul>
</body>
</html>
(2)封装成函数
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>封装成函数</title>
<style>
</style>
<script>
/*通用函数*/
/*用oParent是因为要从元素的父级来取元素本身,sClass就是要查找元素的className,告诉函数所需要的class具体是什么*/
function getByClass (oParent,sClass)
{
var aResult=[];/*先设置一个空数组,把每一个找到的元素先堆到里面*/
var aEle=oParent.getElementsByTagName(‘*‘);/*"*"通配符代表所有的标签,*/
for(var i=0;i<aEle.length;i++)
{
/*如果循环到的标签的className正好是sClass所传递进来的className*/
if(aEle[i].className==sClass)
{
/*,把每一个找到的元素先堆到里面*/
aResult.push(aEle[i]);
}
}
/*直接把一个数组传递出去*/
return aResult;
};
window.onload = function ()
{
var oUl=document.getElementById(‘ul1‘);
var aBox=getByClass(oUl,‘box‘);/*直接调用函数,选取oUl下的className为box的东西*/
for(var i=0;i<aBox.length;i++)
{
aBox[i].style.background=‘red‘;
}
};
</script>
</head>
<body>
<ul id="ul1">
<li class="box"></li>
<li class="box"></li>
<li></li>
<li></li>
<li></li>
<li class="box"></li>
<li></li>
</ul>
</body>
</html>
【JS学习笔记】DOM元素灵活查找