jQuery 소스 code_jquery의 Chunker 일반 필터 분석

WBOY
풀어 주다: 2016-05-16 17:51:14
원래의
1011명이 탐색했습니다.
코드 복사 코드는 다음과 같습니다.
var Chunker = /((?:(((?:([ ^()] )|[^()] ) )|[(?:[[^[]]*]|['"][^'"]*['"]|[^[]'"] ) ]|\. |[^ > ~,([\] ) |[> ~])(s*,s*)?((?:.|r|n)*)/g,

이것은 Jq에서 가장 긴 정규 규칙입니다. 오랫동안 연구해왔지만 항상 혼란스러웠습니다. 디버깅하고 값을 단계별로 분석하면 더 쉽게 이해할 수 있습니다.

아래와 같이 서로 다른 색상이 구분되도록 그래프를 보다 직관적으로 만들려고 했습니다.

jQuery 소스 code_jquery의 Chunker 일반 필터 분석
그룹 1은 하나씩 배열로 분할됩니다. 다음 코드를 통해:
코드 복사 코드는 다음과 같습니다.

// 함수 여기서 루프는 각 선택기를 div#id>p ul li 분할 ['div#id','>','p','ul','li'] while ( (chunker.exec(""), m = Chunker.exec(soFar)) !== null ) {
// soFar는 그룹 3인 첫 번째 레이어를 필터링한 후 선택기 문자열을 저장합니다. 그림
soFar = m[3];
//select 컨테이너 블록의 첫 번째 부분이 배열로 푸시됩니다.
parts.push( m[1] )// 분할된 경우 쉼표 ','로 이전 그룹이 끝나고 루프에서 벗어나 다른 선택 그룹으로 이동합니다.
if ( m[2] ) {
// 다른 선택기 세트 기록
extra = m[3];
break;
}
}


ID, 클래스 등 기타 사항은 이해하기 쉽습니다.


일치: {
// u00c0-uFFFF는 여러 국가의 알파벳 텍스트와 일치합니다. 또는 가족
ID: /#((?:[wu00c0-uFFFF-]|\.) ) /, //예: #myId
CLASS: /.(((?:[wu00c0-uFFFF-] |\.) )/, //예: .myClass
NAME: /[name=['" ]*((?:[wu00c0-uFFFF-]|\.) )['"]*]/ , //예: [name="myName"]
ATTR: /[s*((?:[ wu00c0-uFFFF-]|\.) )s*(?:(S?=)s*( ['"]*)(.*?)3|)s*]/, //예: [attribute=" value"]
TAG: /^((?:[wu00c0-uFFFF*-]| \.) )/, //예: div p a
CHILD: /:(only|nth|last|first) -child(?:((even|odd|[dn -]*)))?/ , //예: :first-child 또는 :nth-child(5n 1)
POS: /:(nth|eq |gt|lt|first|last|even|odd)(?:((d* )))?(?=[^-]|$)/, //예: :nth(3) 범위
PSEUDO : /:(((?:[wu00c0-uFFFF-]|\.) )( ?:((['"]?)((?:([^)] )|[^()]*) )2) )?/ // :jlkjkjl('kl(kklk)kl')
}


계속...
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!