이 기사의 예에서는 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 중국어 웹사이트를 주목하세요!