ホームページ  >  記事  >  ウェブフロントエンド  >  ネイティブ JS を使用して CLASS オブジェクトを取得する (非常にシンプルで実用的)_JavaScript スキル

ネイティブ JS を使用して CLASS オブジェクトを取得する (非常にシンプルで実用的)_JavaScript スキル

WBOY
WBOYオリジナル
2016-05-16 16:33:522179ブラウズ

それが最もよく使われると聞きました。 。 。 。このアイデアは、The Art of DOM Programming を読んだ後に思いつきました。

<!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> 

.ca{background-color:red; padding:20px;} 

.js{ border:1px solid #00F; padding:10px;} 

</style> 

</head> 


<body> 

<div class="ca"> 

sss 

</div> 

<div class="js" id="as"> 

</div> 

<div class="bd"> 

</div> 

<div class="ca"> 

</div> 

</body> 

</html> 

<script> 

function getElementsClass(classnames){ 
var classobj= new Array();//定义数组 

var classint=0;//定义数组的下标 

var tags=document.getElementsByTagName("*");//获取HTML的所有标签 

for(var i in tags){//对标签进行遍历 

if(tags[i].nodeType==1){//判断节点类型 

if(tags[i].getAttribute("class") == classnames)//判断和需要CLASS名字相同的,并组成一个数组 

{ 

classobj[classint]=tags[i]; 

classint++; 

} 

} 

} 

return classobj;//返回组成的数组 

} 


//以下就是测试了 

var a=getElementsClass("ca"); 

a[0].onclick=function(){alert("我们来了");} 

a[1].innerHTML='我们来了'; 

</script>

同じクラスを持つ複数の dom が存在する場合がありますが、これは次のように処理できます:

コードをコピーします コードは次のとおりです:

var a=getElementsClass("ca"); for(var i=0;i (関数(i){
アラート(a[i])
})(i)
}

同じクラスが複数ある場合、それらを一緒に使用できます。JQ にアクセスしたい場合は、さらに複雑な処理を行う必要があります。
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。