Heim Web-Frontend js-Tutorial jQuery源码分析-04 选择器-Sizzle-工作原理分析_jquery

jQuery源码分析-04 选择器-Sizzle-工作原理分析_jquery

May 16, 2016 pm 05:59 PM
工作原理

作者:nuysoft/高云 QQ:47214707 EMail:nuysoft@gmail.com
声明:本文为原创文章,如需转载,请注明来源并保留原文链接。
在分析Sizzle源码之前,先整理一下选择器的工作原理

先明确一些选择器中用到的名词,后边阅读时不会有歧义:

选择器表达式: "div > p"
块表达式: "div" "p"
并列选择器表达式: "div, p"
块分割器: Sizzle中的chunker正则,对选择器表达式从左向右分割出一个个块表达式
查找器: 对块表达式进行查找,找到的DOM元素数组叫候选集
过滤器: 对块表达式和候选集进行过滤
关系过滤器 对块表达式之间的关系进行过滤,共有四种关系:"+" 紧挨着的兄弟关系;">" 父子关系;"" 祖先关系;"~" 之后的所有兄弟关系
候选集: 查找器的结果,待过滤器进行过滤
映射集: 候选集的副本,过滤器和关系过滤器对映射集进行过滤

工作流程:

1. 使用块分割器对选择器表达式进行分割,从左向右
如果遇到用逗号","分割的并列选择器表达式,只分割至第一个逗号前边的选择器表达式1,将剩余部分记录下来

2. 对最后一个块表达式进行查找Sizzle.find,结果放入候选集set,并将块表达式中匹配的字符串部分删除
查找器Sizzle.find从正则集Expr.match获取对应的正则表达式,对块表达式进行匹配,匹配成功则从查找函数集Expr.find获取对应的查找函数执行
查找顺序定义在Expr.order中,依次是:ID CLASS NAME TAG,查找时CLASS需要浏览器支持getElementsByClassName
Expr.match中设定了ID CLASS NAME ATTR TAG CHILD POS PSEUDO的正则匹配表达式

3. 如果最后一个块表达式不为空(字符串),过滤器Sizzle.filter对set进行过滤
过滤器Sizzle.filter仅对单个块表达式起作用,仅对候选集set中的元素起作用,检查候选集set中的元素满足剩余的块表达式
在过滤器Sizzle.filter的过滤过程中,不符合条件的被设置为false,符合条件的不做修改
过滤时从正则集Expr.leftMatch获取对应的正则表达式,对块表达式进行匹配,匹配成功则从Expr.filter获取对应的过滤函数执行
Expr.leftMatch定义了与Expr.match同样数量的正则表达式:ID CLASS NAME ATTR TAG CHILD POS PSEUDO
过滤函数集Expr.filter定义了PSEUDO CHILD ID TAG CLASS ATTR POS的过滤函数
过滤器Sizzle.filter进行过滤之前,会先调用预过滤器Expr.preFilter对过滤所需的参数进行修正,但是CLASS是个例外
在CLASS进行预过滤时做了优化,直接将匹配class的元素作为候选集返回,缩小过滤范围,缩小候选集范围
将以上查找和过滤得到候选集set复制,放入映射集checkSet,后边的过滤操作在checkSet上进行
对最后一个块表达式的查找和过滤到这里结束,得到一个候选集set和映射集checkSet

4. 在映射集checkSet上将剩余的块表达式从右向左进行过滤,根据与前一个块表达式的关系,从关系过滤器集Expr.relative中获取对应的函数执行关系过滤
在关系过滤器Expr.relative的过滤过程中,不符合条件的被设置为false,符合条件的则被设置为父元素、祖先元素、兄长元素
元素之间的关系共有四种:"+" 紧挨着的兄弟关系;">" 父子关系;"" 祖先关系;"~" 之后的所有兄弟关系
在关系过滤器Expr.relative的过滤过程中,如果遇到块表达式是标签TAG的情况,则直接比较标签类型nodeName是否相等
如果不是标签TAG的情况,则会调用过滤器Sizzle.filter进行过滤,过滤过程见第3步
从右向左过滤,直到所有块表达式全部过滤完

5. 根据过滤后的映射集checkSet,从候选集set中挑选最终的结果集,在映射集checkSet中
如果是null、false,将被过滤
如果不是Element(nodeType===1),将被过滤
如果上下文不是Document而是某个Element,不是Element的子元素的,将被过滤

6. 如果存在并列表达式,重复1~5,并将得到的最终结果集合并、排序、去重
如果仅有一个选择器表达式,没有并列选择器表达式,不需要排序

以下过程不属于Sizzle,属于jQuery对Sizzle的扩展

7. 如果存在多个上下文,对每个上下文重复1~6
多个上下文例子:$('div').find('div > p'),$('div')可能找到多个div
其实第7步是jQuery选择器的入口,从第7步去调用1~6,调用时传入一个空的jQuery对象作为结果集
默认以document为上下文:(context || rootjQuery).find( selector )

8. 将从多个上下文找到的结果集合并、去重,返回结果集

done!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Was ist eine SOL-Münze? Wie funktioniert die SOL-Münze? Was ist eine SOL-Münze? Wie funktioniert die SOL-Münze? Mar 16, 2024 am 10:37 AM

Solana Blockchain und SOL Token Solana ist eine Blockchain-Plattform, die sich auf die Bereitstellung hoher Leistung, Sicherheit und Skalierbarkeit für dezentrale Anwendungen (dApps) konzentriert. Als nativer Vermögenswert der Solana-Blockchain werden SOL-Token hauptsächlich zur Zahlung von Transaktionsgebühren, zur Verpfändung und zur Teilnahme an Governance-Entscheidungen verwendet. Die einzigartigen Merkmale von Solana sind die schnellen Transaktionsbestätigungszeiten und der hohe Durchsatz, was es zu einer bevorzugten Wahl bei Entwicklern und Benutzern macht. Durch SOL-Tokens können Nutzer an verschiedenen Aktivitäten des Solana-Ökosystems teilnehmen und gemeinsam die Entwicklung und den Fortschritt der Plattform vorantreiben. So funktioniert Solana Solana nutzt einen innovativen Konsensmechanismus namens Proof of History (PoH), der in der Lage ist, Tausende von Transaktionen effizient zu verarbeiten.

Was ist die Architektur und das Arbeitsprinzip von Spring Data JPA? Was ist die Architektur und das Arbeitsprinzip von Spring Data JPA? Apr 17, 2024 pm 02:48 PM

SpringDataJPA basiert auf der JPA-Architektur und interagiert mit der Datenbank über Mapping, ORM und Transaktionsmanagement. Sein Repository bietet CRUD-Operationen und abgeleitete Abfragen vereinfachen den Datenbankzugriff. Darüber hinaus nutzt es Lazy Loading, um Daten nur bei Bedarf abzurufen und so die Leistung zu verbessern.

Was ist eine Polygonmünze? Wie funktioniert die Polygon-Münze? Was ist eine Polygonmünze? Wie funktioniert die Polygon-Münze? Mar 16, 2024 am 09:22 AM

Polygon: Eine multifunktionale Blockchain, die das Ethereum-Ökosystem aufbaut. Polygon ist eine multifunktionale Blockchain-Plattform auf Basis von Ethereum, früher bekannt als MaticNetwork. Sein Ziel ist es, die Skalierbarkeits-, hohen Gebühren- und Komplexitätsprobleme im Ethereum-Netzwerk zu lösen. Polygon bietet Entwicklern und Benutzern durch die Bereitstellung von Skalierbarkeitslösungen ein schnelleres, günstigeres und einfacheres Blockchain-Erlebnis. So funktioniert Polygon: Sidechain-Netzwerk: Polygon erstellt ein Netzwerk aus mehreren Sidechains. Diese Sidechains laufen parallel zur Ethereum-Hauptkette und können große Transaktionsvolumina verarbeiten, wodurch der gesamte Netzwerkdurchsatz erhöht wird. Plasma-Framework: Polygon nutzt das Plasma-Framework, das

Was ist eine VET-Münze? Wie funktioniert die VET-Münze? Was ist eine VET-Münze? Wie funktioniert die VET-Münze? Mar 16, 2024 am 11:40 AM

VET Coin: Blockchain-basiertes IoT-Ökosystem VeChainThor (VET) ist eine auf Blockchain-Technologie basierende Plattform, die darauf abzielt, den Bereich Internet der Dinge (IoT) zu verbessern, indem sie die Glaubwürdigkeit von Daten gewährleistet und einen sicheren Transfer von Wertschöpfungsketten und Geschäftsprozessen ermöglicht . VET Coin ist der native Token der VeChainThor-Blockchain und hat die folgenden Funktionen: Transaktionsgebühren bezahlen: VET Coins werden zur Zahlung von Transaktionsgebühren im VeChainThor-Netzwerk verwendet, einschließlich Datenspeicherung, Ausführung intelligenter Verträge und Identitätsprüfung. Governance: VET-Token-Inhaber können an der Governance von VeChainThor teilnehmen, einschließlich der Abstimmung über Plattform-Upgrades und Vorschläge. Anreize: Berufsbildungsmünzen werden verwendet, um Prüfern im Netzwerk Anreize zu bieten, die sicherzustellen

Was ist eine SHIB-Münze? Wie funktioniert die SHIB-Münze? Was ist eine SHIB-Münze? Wie funktioniert die SHIB-Münze? Mar 17, 2024 am 08:49 AM

ShibaInu Coin: Von Hunden inspirierte Kryptowährung ShibaInu Coin (SHIB) ist eine dezentrale Kryptowährung, die vom legendären Shiba Inu-Emoji inspiriert ist. Die Kryptowährung wurde im August 2020 eingeführt und soll eine Alternative zu Dogecoin im Ethereum-Netzwerk sein. Funktionsprinzip SHIB-Coin ist eine digitale Währung, die auf der Ethereum-Blockchain basiert und dem ERC-20-Token-Standard entspricht. Es nutzt einen dezentralen Konsensmechanismus, Proof of Stake (PoS), der es Inhabern ermöglicht, ihre SHIB-Tokens einzusetzen, um Transaktionen zu verifizieren und dafür Belohnungen zu verdienen. Hauptmerkmale Riesiges Angebot: Der anfängliche Bestand an SHIB-Münzen beträgt 1.000 Billionen Münzen und ist damit eine der größten im Umlauf befindlichen Kryptowährungen. Niedrige Preise

Was ist eine Algorand-Münze? Wie funktioniert die Algorand-Münze? Was ist eine Algorand-Münze? Wie funktioniert die Algorand-Münze? Mar 17, 2024 am 08:30 AM

Algorand: Eine Blockchain-Plattform, die auf dem rein byzantinischen Konsensprotokoll basiert. Algorand ist eine Blockchain-Plattform, die auf dem rein byzantinischen Konsensprotokoll basiert und darauf abzielt, effiziente, sichere und skalierbare Blockchain-Lösungen bereitzustellen. Die Plattform wurde 2017 von MIT-Professor Silvio Micali gegründet. Funktionsprinzip Der Kern von Algorand liegt in seinem einzigartigen rein byzantinischen Konsensprotokoll, dem Algorand-Konsens. Dieses Protokoll ermöglicht es Knoten, in einer vertrauenswürdigen Umgebung einen Konsens zu erzielen, selbst wenn sich bösartige Knoten im Netzwerk befinden. Der Algorand-Konsens erreicht dieses Ziel durch eine Reihe von Schritten. Schlüsselgenerierung: Jeder Knoten generiert ein Paar öffentlicher und privater Schlüssel. Vorschlagsphase: Ein zufällig ausgewählter Knoten schlägt eine neue Zone vor

Was ist Beam Coin? Wie funktioniert Beam Coin? Was ist Beam Coin? Wie funktioniert Beam Coin? Mar 15, 2024 pm 09:50 PM

Beam Coin: Datenschutzorientierte Kryptowährung Beam Coin ist eine datenschutzorientierte Kryptowährung, die für sichere und anonyme Transaktionen entwickelt wurde. Es nutzt das MimbleWimble-Protokoll, eine Blockchain-Technologie, die die Privatsphäre der Benutzer verbessert, indem sie Transaktionen zusammenführt und die Adressen von Absendern und Empfängern verbirgt. Das Designkonzept von Beam Coin besteht darin, Benutzern eine digitale Währungsoption bereitzustellen, die die Vertraulichkeit von Transaktionsinformationen gewährleistet. Durch die Übernahme dieses Protokolls können Benutzer Transaktionen mit größerem Vertrauen durchführen, ohne befürchten zu müssen, dass ihre persönlichen Daten verloren gehen. Durch diese Funktion zum Schutz der Privatsphäre verbessert das MimbleWimble-Protokoll die Privatsphäre durch: Zusammenführen von Transaktionen: Es kombiniert mehrere Transaktionen

Was ist eine AR-Münze? Wie funktioniert die AR-Münze? Was ist eine AR-Münze? Wie funktioniert die AR-Münze? Mar 15, 2024 pm 07:25 PM

AR Coin: Digitale Währung basierend auf Augmented-Reality-Technologie AR Coin ist eine digitale Währung, die Augmented-Reality-Technologie nutzt, um Benutzern die Erfahrung der Interaktion mit digitalen Inhalten zu bieten und es ihnen zu ermöglichen, immersive Erlebnisse in der realen Welt zu schaffen. Wie es funktioniert AR Coin basiert auf den folgenden Schlüsselkonzepten: Augmented Reality (AR): AR-Technologie überlagert digitale Informationen mit der realen Welt und ermöglicht Benutzern die Interaktion mit virtuellen Objekten. Blockchain: Blockchain ist eine Distributed-Ledger-Technologie zur Aufzeichnung und Überprüfung von Transaktionen. Es bietet Sicherheit und Transparenz für AR-Münzen. Smart Contracts: Smart Contracts sind in der Blockchain gespeicherte Codes, die zur Automatisierung bestimmter Vorgänge verwendet werden. Sie spielen eine entscheidende Rolle bei der Erstellung und Verwaltung von AR-Münzen. Der Arbeitsablauf von AR-Münzen ist wie folgt: Erstellen Sie einen AR-Körper

See all articles