首页  >  问答  >  正文

使用正则表达式匹配id值

<p>我想找到所有值为<code>id</code>属性由以下组成的<code>g</code>节点的子节点:</p> <pre class="brush:php;toolbar:false;">a[number]-[一个或多个字符] // 例子: // - id="a1-a" // - id="a1-b" // - id="a1-abcd" // - id="a10-f" // - id="a0-z" // - id="b1-a" // 不合法 // - id="a1-2" // 不合法</pre> <p>所以我尝试了:</p> <pre class="lang-js prettyprint-override"><code>const items = gElement.querySelectorAll(`[id^='a[0-9]+-[a-zA-Z]+']`) </code></pre> <p>但是,它不起作用。</p>
P粉757556355P粉757556355395 天前521

全部回复(1)我来回复

  • P粉237647645

    P粉2376476452023-08-31 10:23:22

    在你的查询选择器中,你使用的模式 ([0-9]+) 没有被解释为正则表达式。使用 RegExp 构造函数从字符串创建一个正则表达式对象:

    const regex = new RegExp('^a[0-9]+-[a-zA-Z]+$');
    const parentElement = document.querySelector('#parent-element');
    const items = parentElement.querySelectorAll(`[id]`);
    const children = Array.from(items).filter(item => regex.test(item.id));
    
    console.log(children); 
    <div id="parent-element">
      <p id="a1-a">Child 1</p>
      <p id="a1-b">Child 2</p>
      <p id="INVALID-1">Child 3</p>
      <p id="a10-f">Child 4</p>
      <p id="INVALID-2">Child 5</p>
      <p id="b1-a">Child 6</p>
      <p id="a1-2">Child 7</p>
    </div>

    回复
    0
  • 取消回复