[class]与[class=""]
群里的abcd提出的问题,选择器如何区分这两个东西。说实话,我对此非常迷惑,于是看了几个选择器的实现,总结如下:
[class]要求目标节点显式地设置了class。
[class=""]不但要求目标节点显式地设置class,还要求其值为空字符串。
那剩下的问题是如何得知此属性是被显式地设置了。这简单,这东西我老早就在《tabIndex属性》一文研究过:
var _hasAttr = function (node, name){ var attr = node.getAttributeNode && node.getAttributeNode(name); return attr && attr.specified; // Boolean }; |
但对于一个选择器来说,过来的函数调用是非常不明显,我们需要努力寻求一些更简捷的替换品。hasAttribute不错,可惜IE6,IE7不支持。我们转向jQuery源码吧,毕竟拥有这些人为它添加砖加瓦。
由于它是属于属性选择器的范畴,因此它与[name=check],[name!=check],[name~=check]等一齐处理。jQuery会把它进行切割,如[name=check]会变成["name","name","=","check"],[name!=check]会变成["name","name","!=","check"],[name]会变成["name","name",,],亦即有两个元素是undefined。第四个值会代入一个叫check的变量,并且再与""相加代入另一个叫value的变量。在那个长长的三目运算符中,它有一个分支专门用于处理像[class]这种是否显示地设置了属性但不管其值是多少的情况:
!check ? value && result !== false : //当check为undefined,即进入此分支,result为真实属性值 |
如果您觉得此文有帮助,可以打赏点钱给我支付宝1669866773@qq.com ,或扫描二维码


机器瞎学/数据掩埋/模式混淆/人工智障/深度遗忘/神经掉线/计算机幻觉/专注单身二十五年
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
2010-01-06 高效地获取XMLhttp对象