四.jQuery源码解析之jQuery.fn.init()的参数解析

四.jQuery源码解析之jQuery.fn.init()的参数解析

从return new jQuery.fn.init( selector, context, rootjQuery )中可以看出
参数selector和context是来自我们在调用jQuery方法时传过来的.
那么selector和context都有哪些可能.

四.jQuery源码解析之jQuery.fn.init()的参数解析

 

对于表格中的4~9行中的可能做具体分析.
四.jQuery源码解析之jQuery.fn.init()的参数解析

如果selector是字符串,则首先检测是html代码还是#id.
126行的if语句:以"<"开头,以">"结尾,且长度>=3.则假设额这个是HTML片段,这里只是假设不一定就是合肥的html代码.比如"<div><guofsfsdfd>";
130行的else:表示不是html代码.这个时候用正则表达式来检测.
四.jQuery源码解析之jQuery.fn.init()的参数解析
我对正则不是很懂.不过大致可以看懂,匹配的是html和id.匹配的结果赋值给match.

分析完了selector,context参数后,我们是不是忘了rootjQuery参数.
这个参数是jQuery内部定义的.不是我们手动从外部传入的.
从名字上我们大概能猜出这个参数的大概情况了:根部的jQuery对象.
看源码定义:

四.jQuery源码解析之jQuery.fn.init()的参数解析
那么什么情况下,程序会用到这个参数呢?
1.当document.getElementById()查找失败,

四.jQuery源码解析之jQuery.fn.init()的参数解析
2.selector是函数:

四.jQuery源码解析之jQuery.fn.init()的参数解析
3.selector是选择器表达式,且未指定context;

四.jQuery源码解析之jQuery.fn.init()的参数解析

四.jQuery源码解析之jQuery.fn.init()的参数解析,布布扣,bubuko.com

四.jQuery源码解析之jQuery.fn.init()的参数解析

上一篇:Silverlight下组合键、快捷键的使用方法


下一篇:纯CSS3实现淡入淡出下拉菜单