其他教程

其他教程

Products

当前位置:首页 > 其他教程 >

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

GG网络技术分享 2025-03-18 16:15 10


问题描述:

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

网友观点:

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

 为什么要用正则表达式,用jquery不行么?

$(“.none p”).each(function() {})

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

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特别方便(这是它的长项)

JavaScript中正则表达式使用教程,什么情况下使用正则,正则的理解

是什么

正则表达式是一种用来匹配字符串的强有力的武器

它的设计思想是用一种描述性的语言定义一个规则,凡是符合规则的字符串,我们就认为它“匹配”了,否则,该字符串就是不合法的

根据正则表达式语法规则,大部分字符仅能够描述自身,这些字符被称为普通字符,如所有的字母、数字等。

元字符就是拥有特动功能的特殊字符,大部分需要加反斜杠进行标识,以便于普通字符进行区别,而少数元字符,需要加反斜杠,以便转译为普通字符使用。JavaScript 正则表达式支持的元字符如表所示。

在 JavaScript中,正则表达式也是对象,构建正则表达式有两种方式:

  1. 字面量创建,其由包含在斜杠之间的模式组成

标签:

提交需求或反馈

Demand feedback