请问如何使用js正则表达式获取所有class="none"的p标签,使用数组存储

请问如何使用js正则表达式获取所有class="none"的p标签,使用数组存储

5个回答

 <!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<title>找出所有class=none的p标签</title>
</head>
<body>
    <div class="container">
        <p id="test" class="none">P1</p>
        <span>test</span>
        <p >p2</p>
        <div>
            <P Class = "None">P3</p>
        </div>
        <p>P4</p>
    </div>

    <script type="text/javascript">
        var src =  document.body.innerHTML;
        var reg = /<p.*?class[ \t]*=[ \t]*"none".*?>.*?<\/p>/ig;
        var res = src.match(reg); //获取的P标签数组
        var i;
        for(i=0; i< res.length; i++){
            console.log(res[i]);
        }

    </script>
</body>
</html>
ddu_163
ddu_163 这遍总算对了
大约 2 年之前 回复
 为什么要用正则表达式,用jquery不行么?
$(“.none p”).each(function() {})

正则表达式需要考虑很多因素,比如说class属性值在属性的位置,元素是闭合和嵌套等等。

bgxlj
bgxlj 回复bgxlj: getElementsByClassName(),打错了
大约 2 年之前 回复
bgxlj
bgxlj 无所谓的,class属性又不是以单个字符串的形式储存,你不论为元素以任何顺序增加了多少个class直接用getElementById()就能获取
大约 2 年之前 回复

let p = document.getElementsByTagName("p"),
myP = [];
for(let i = 0; i < p.length; i++){
if(p[i].className.match("none")){
myP.push(p[i]);
}
}
console.log(myP);

/

.*?<\/p>/ig 这个正则就可以

不推介用正则表达式,用jquery特别方便(这是它的长项)

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问