>웹 프론트엔드 >JS 튜토리얼 >JS 정규식의 비캡처 그룹화 사용 분석 예

JS 정규식의 비캡처 그룹화 사용 분석 예

高洛峰
高洛峰원래의
2017-01-09 15:48:131383검색

이 기사의 예에서는 JS 정규 표현식의 비캡처 그룹화 사용법을 설명합니다. 참고하실 수 있도록 공유해 드리며, 자세한 내용은 다음과 같습니다.

최근 JsonSQL을 보다가 소스코드의 정규식을 통해 non-capturing grouping이 무엇인지, 그 활용 시나리오를 배웠습니다. js에서 일반 캡처 그룹화 형식은 (XX)이고 비캡처 그룹화 형식은 (?:XX)입니다. 정규식 수량자부터 시작하겠습니다. 문자 b가 최소한 한 번 나타나도록 하려면 일반 /b+/를 사용할 수 있습니다. ab가 최소한 한 번 나타나도록 하려면 /(ab)+/를 사용해야 합니다. /ab+/가 아닙니다. 즉, 여러 문자에 수량자를 사용하려면 괄호를 사용해야 합니다.

var str = "a1***ab1cd2***c2";
var reg1 = /((ab)+\d+)((cd)+\d+)/i;
var reg2 = /((?:ab)+\d+)((?:cd)+\d+)/i;
alert(str.match(reg1));//ab1cd2,ab1,ab,cd2,cd
alert(str.match(reg2));//ab1cd2,ab1,cd2

캡처 그룹과 비캡처 그룹의 차이점을 확인할 수 있습니다. 비캡처 그룹은 일치에만 사용되며 그룹을 추출하지 않습니다. 콘텐츠. . 즉, 수량자로 일부 문자를 수정하기 위해 괄호만 사용하려는 경우 비캡처 그룹인 이 그룹의 내용은 필요하지 않습니다.

다음 코드는 SQL 문에서 다양한 하위 조각을 추출하는 데 사용됩니다. 비캡처 그룹을 많이 사용하므로 자세히 살펴볼 수 있습니다.

var returnfields = sql.match(/^\s*SELECT\s+((?:[0-9A-Za-z_]+\s*,\s*)+[0-9A-Za-z_]+ |\*|[0-9A-Za-z_]+)\s+FROM\s+([a-z0-9A-Z_]+)(?: where\s+(.+))?(?:\s+order\s+by\s+([a-z0-9_A-Z]+)(?:\s+(asc|desc|ascnum|descnum)?))?(?:\s+limit\s+(\d+,\d+))?/i);
var ops = {
  fields: returnfields[1].replace('\s','').split(','),
  from: returnfields[2].replace('\s',''),
  where: (returnfields[3] == undefined)? "true":returnfields[3],
  orderby: (returnfields[4] == undefined)? []:returnfields[4].replace('\s','').split(','),
  order: (returnfields[5] == undefined)? "asc":returnfields[5],
  limit: (returnfields[6] == undefined)? []:returnfields[6].replace('\s','').split(',')
};

이 일반 규칙에 대해 여러 가지 설명이 있습니다.

1. 필드 이름과 표시는 대문자와 소문자로만 구성될 수 있습니다. 문자, 숫자와 밑줄로 구성됩니다.

2. where 뒤의 조건은 () 안에 들어가야 합니다. 그렇지 않으면 일치하지 않습니다. 이는 실제 SQL과 다릅니다.

3. select 다음 필드에는 단일 필드, 다중 필드(쉼표로 구분), 모든 필드(*로 표시)의 3가지 형식이 있습니다.

4. where 하위 명령문, order by 하위 명령문, 제한 하위 명령문은 모두 선택 사항입니다.

다음 텍스트는 위의 정규식과 일치할 수 있습니다.

select age from data where (name=='aty')

이 기사가 JavaScript 프로그래밍에 종사하는 모든 사람에게 도움이 되기를 바랍니다.

JS 정규식의 비캡처 그룹화 사용 예에 ​​대한 더 많은 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.