jQuery源码分析-04 选择器-Sizzle-工作原理分析_jquery
作者: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!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Solana区块链和SOL代币Solana是一种专注于为去中心化应用程序(dApps)提供高性能、安全和可扩展性的区块链平台。SOL代币作为Solana区块链的原生资产,主要用于支付交易手续费、质押和参与治理决策。Solana的独特之处在于其快速的交易确认时间和高吞吐量,使其成为开发者和用户青睐的选择。通过SOL代币,用户可以参与Solana生态系统的各种活动,并共同推动平台的发展和进步。Solana的工作原理Solana采用一种创新的共识机制,被称为历史证明(PoH),能够有效处理数千笔交易。

SpringDataJPA基于JPA架构,通过映射、ORM和事务管理与数据库交互。其存储库提供CRUD操作,派生查询简化了数据库访问。此外,它使用延迟加载,仅在必要时检索数据,从而提高了性能。

Polygon:构建以太坊生态系统的多功能区块链Polygon是一个建立在以太坊之上的多功能区块链平台,原名为MaticNetwork。其目标是解决以太坊网络中的可扩展性、高费用和复杂性问题。Polygon通过提供可扩展性解决方案,为开发者和用户提供更快速、更便宜、更简单的区块链体验。Polygon的工作原理如下:侧链网络:Polygon创建了一个由多个侧链组成的网络。这些侧链与以太坊主链并行运行,可以处理大量交易,从而提高整体网络吞吐量。Plasma框架:Polygon利用Plasma框架,这

VET币:基于区块链的物联网生态系统VeChainThor(VET)是一种基于区块链技术的平台,旨在通过确保数据的可信性和实现价值的安全转移来提升物联网(IoT)领域的供应链管理和业务流程。VET币是VeChainThor区块链的原生代币,具有以下功能:支付交易费用:VET币用于支付VeChainThor网络上的交易费用,包括数据存储、智能合约执行和身份验证。治理:VET币持有者可以参与VeChainThor的治理,包括对平台升级和提案进行投票。激励:VET币用于激励网络中的验证者,以确保网络的

ShibaInu币:以狗狗为灵感的加密货币ShibaInu币(SHIB)是一种去中心化的加密货币,灵感源自于其标志性的柴犬表情包。该加密货币于2020年8月推出,旨在成为以太坊网络上的一种替代狗狗币。工作原理SHIB币是建立在以太坊区块链上的数字货币,符合ERC-20代币标准。它运用去中心化共识机制,即权益证明(PoS),这使得持有者可以通过抵押他们的SHIB代币来验证交易,并从中获得奖励。主要特点庞大的供应量:SHIB币的初始供应量为1000万亿枚,使其成为流通量最大的加密货币之一。低价格:S

Algorand:基于纯拜占庭共识协议的区块链平台Algorand是建立在纯拜占庭共识协议之上的区块链平台,旨在提供高效、安全且可扩展的区块链解决方案。这一平台由麻省理工学院的教授SilvioMicali于2017年创立。工作原理Algorand的核心在于其独特的纯拜占庭共识协议,即Algorand共识。这个协议允许节点在不信任的环境中实现共识,即使网络中存在恶意节点。Algorand共识通过一系列步骤来实现这一目标。密钥生成:每个节点生成一对公钥和私钥。提议阶段:一个随机选择的节点提议一个新区

Beam币:注重隐私的加密货币Beam币是一种专注于隐私保护的加密货币,旨在提供安全且匿名的交易。它采用了MimbleWimble协议,这是一种区块链技术,通过合并交易和隐藏发送者与接收者的地址来增强用户的隐私保护。Beam币的设计理念是为用户提供一种能够确保交易信息保密的数字货币选择。通过采用这种协议,用户可以更加放心地进行交易,而无需担心他们的个人隐私信息被泄露。这种隐私保护的特性使得Beam币Beam币的工作原理MimbleWimble协议通过以下方式增强隐私:交易合并:它将多个交易组合成

AR币:基于增强现实技术的数字货币AR币是一种数字货币,利用增强现实技术为用户提供与数字内容互动的体验,使他们可以在现实世界中创造身临其境的体验。工作原理AR币的工作原理基于以下关键概念:增强现实(AR):AR技术将数字信息叠加在现实世界中,使用户能够与虚拟对象进行交互。区块链:区块链是一种分布式账本技术,用于记录和验证交易。它为AR币提供安全性和透明度。智能合约:智能合约是存储在区块链上的代码,用于自动化特定操作。它们在AR币的创建和管理中发挥着至关重要的作用。AR币的工作流程如下:创建AR体
