Expr.preFilter是tokenize方法中对ATTR、CHILD、PSEUDO三种选择器进行预处理的方法。具体如下:
Expr.preFilter : { "ATTR" : function(match) { /* * 完成如下任务: * 1、属性名称解码 * 2、属性值解码 * 3、若判断符为~=,则在属性值两边加上空格 * 4、返回最终的mtach对象 * * match[1]表示属性名称, * match[1].replace(runescape, funescape):将属性名称中的十六进制数解码成 * 单字节unicode字符或双字节unicode字符(中文或其它需要两个字节表达的文字) * 正则表达式的详细说明,可以参看我的“详解jQuery选择器正则表达式”文章 */ match[1] = match[1].replace(runescape, funescape); /* * 将属性值解码 * match[4]:表示放在单引号或双引号内的属性值 * match[5]: 表示不用引号括起来的属性值 */ match[3] = (match[4] || match[5] || "").replace(runescape, funescape); /* * ~=的意思是单词匹配,在W3C中对单词的定义是以空白为不同单词的分隔符 * 故此处在match[3]两边加上空格后,可以利用indexOf,正确识别出该单词是否存在 */ if (match[2] === "~=") { match[3] = " " + match[3] + " "; } /* * 返回有用的前四个元素结果 */ return match.slice(0, 4); }, "CHILD" : function(match) { /* * 完成如下几项任务: * 1、把命令中child和of-type之前的字符变成小写字符 * 2、对于nth开头的选择器检查括号内的数据有效性 * 3、match[4]和match[5]分别存放xn+b中的x和b,x和b允许是负数 * 4、返回最终的match对象 * * match[1]:(only|first|last|nth|nth-last)中的一个 */ match[1] = match[1].toLowerCase(); /* * 对于nth-child、nth-of-type、nth-last-child、nth-last-of-type四种类型括号内需设置有效数据 * 而其它则括号内不允许有任何数据 */ if (match[1].slice(0, 3) === "nth") { /* * 若选择器括号内没有有效参数,则抛出异常 * 举例:若选择器是nth或nth(abc)则属于非法选择器 */ if (!match[3]) { Sizzle.error(match[0]); } /* * 下面先以nth-child()为例介绍一下语法,以便更好的理解下面代码的作用 * nth-child允许的几种使用方式如下: * :nth-child(even) * :nth-child(odd) * :nth-child(3n) * :nth-child(+2n+1) * :nth-child(2n-1) * 下面代码中赋值号左侧的match[4]、match[5]用于分别记录括号内n前及n后的数值,包括正负号 * 对于:nth-child(even)和:nth-child(odd)来说,match[4]为空, * 所以返回 2 * (match[3] === "even" || match[3] === "odd")的计算结果 * 因为在js中true=1,false=0,所以(match[3] === "even" || match[3] === "odd")等于1 * 因此,2 * (match[3] === "even" || match[3] === "odd")的计算结果为2 * * 等号右侧的“+”的作用是强制类型转换,将之后的字符串转换成数值类型 */ match[4] = +(match[4] ? match[5] + (match[6] || 1) : 2 * (match[3] === "even" || match[3] === "odd")); match[5] = +((match[7] + match[8]) || match[3] === "odd"); } else if (match[3]) { /* * 若非nth起头的其它CHILD类型选择器带有括号说明,则抛出异常 * 这里jQuery并没有严格按照W3C的规则来判定,因为其允许:first-child()的这种形式存在 * 也就是对于jQuery来说:first-child()等同于:first-child,是合法选择器 */ Sizzle.error(match[0]); } return match; }, "PSEUDO" : function(match) { /* * 完成如下任务: * 1、获取伪类中用引号括起来的值 * 2、对于非引号括起来的值,若存在伪类嵌套,则进一步解析确定当前伪类实际结束位置, * 获取当前伪类的完整字符串和值 * 3、返回match中的前三项的副本。 * * unquoted表示括号内非引号括起来的值, * 以:eq(2)为例,unquoted=2 */ var excess, unquoted = !match[5] && match[2]; /* * 因为pseudo与child的匹配正则表达式有交集,所以,需要把属于child的部分忽略掉 */ if (matchExpr["CHILD"].test(match[0])) { return null; } /* * 若括号内的值使用引号(match[3])括起来的, * 则将除引号外的值(match[4])赋给match[2]。 * match[3]表示引号。 */ if (match[3] && match[4] !== undefined) { match[2] = match[4]; } else if (unquoted /* * rpseudo.test(unquoted):用来测试unquoted是否包含伪类, * 若包含伪类,则说明有可能存在伪类嵌套的可能性,需要进一步对unquoted进行解析 * 例如: :not(:eq(3)) */ && rpseudo.test(unquoted) && /* * 获取unquoted中连续有效地选择器最后一个字符所在位置 */ (excess = tokenize(unquoted, true)) && /* * unquoted.indexOf(")", unquoted.length - excess) * 从之前获得的连续有效地选择器最后一个字符所在位置之后找到")"所在位置, * 通常就在当前位置之后。 * 再减去unquoted.length,用来获得match[0]中的有效完整的伪类字符串最后位置, * 注意,此时excess是一个负值 * */ (excess = unquoted.indexOf(")", unquoted.length - excess) - unquoted.length)) { // 获取有效的完整伪类match[0]和伪类括号内的数据match[2] match[0] = match[0].slice(0, excess); match[2] = unquoted.slice(0, excess); } // 返回match前三个元素的副本 return match.slice(0, 3); } }

Python和JavaScript的主要区别在于类型系统和应用场景。1.Python使用动态类型,适合科学计算和数据分析。2.JavaScript采用弱类型,广泛用于前端和全栈开发。两者在异步编程和性能优化上各有优势,选择时应根据项目需求决定。

选择Python还是JavaScript取决于项目类型:1)数据科学和自动化任务选择Python;2)前端和全栈开发选择JavaScript。Python因其在数据处理和自动化方面的强大库而备受青睐,而JavaScript则因其在网页交互和全栈开发中的优势而不可或缺。

Python和JavaScript各有优势,选择取决于项目需求和个人偏好。1.Python易学,语法简洁,适用于数据科学和后端开发,但执行速度较慢。2.JavaScript在前端开发中无处不在,异步编程能力强,Node.js使其适用于全栈开发,但语法可能复杂且易出错。

javascriptisnotbuiltoncorc; saninterpretedlanguagethatrunsonenginesoftenwritteninc.1)javascriptwasdesignedAsalightweight,解释edganguageforwebbrowsers.2)Enginesevolvedfromsimpleterterterpretpreterterterpretertestojitcompilerers,典型地提示。

JavaScript可用于前端和后端开发。前端通过DOM操作增强用户体验,后端通过Node.js处理服务器任务。1.前端示例:改变网页文本内容。2.后端示例:创建Node.js服务器。

选择Python还是JavaScript应基于职业发展、学习曲线和生态系统:1)职业发展:Python适合数据科学和后端开发,JavaScript适合前端和全栈开发。2)学习曲线:Python语法简洁,适合初学者;JavaScript语法灵活。3)生态系统:Python有丰富的科学计算库,JavaScript有强大的前端框架。

JavaScript框架的强大之处在于简化开发、提升用户体验和应用性能。选择框架时应考虑:1.项目规模和复杂度,2.团队经验,3.生态系统和社区支持。

引言我知道你可能会觉得奇怪,JavaScript、C 和浏览器之间到底有什么关系?它们之间看似毫无关联,但实际上,它们在现代网络开发中扮演着非常重要的角色。今天我们就来深入探讨一下这三者之间的紧密联系。通过这篇文章,你将了解到JavaScript如何在浏览器中运行,C 在浏览器引擎中的作用,以及它们如何共同推动网页的渲染和交互。JavaScript与浏览器的关系我们都知道,JavaScript是前端开发的核心语言,它直接在浏览器中运行,让网页变得生动有趣。你是否曾经想过,为什么JavaScr


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

Dreamweaver Mac版
视觉化网页开发工具

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

WebStorm Mac版
好用的JavaScript开发工具