Kaedah lulus parameter untuk permulaan objek jQuery termasuk:
1.$(DOMElement)
2.$('
...
'), $('#id'), $('.class') lulus dalam rentetan Ini ialah bentuk yang paling biasa sering diluluskan sebagai konteks parameter kedua untuk menentukan konteks, di mana parameter konteks boleh menjadi $(...), DOMElement
3.$(fungsi() {}); <===> $(dokumen).sedia(fungsi() { });
4.$({selector : '.class', context : context}) <===> $('.class', context)
jQuery.fn = jQuery.prototype = {
Pembina: jQuery,
init: fungsi(pemilih, konteks, rootjQuery) {
var padanan, elem, ret, doc;
// Proseskan parameter $(""), $(null), $(undefined), $(false) dan terus kembalikan ini
jika ( !pemilih ) {
kembalikan ini;
}
// Apabila pemilih parameter yang diluluskan ialah nod DOM, tetapkan konteks kepada pemilih
Jika (selector.nodeType) {
This.context = this[0] = pemilih;
This.length = 1;
kembalikan ini;
}
// Kendalikan rentetan HTML
// Apabila parameter pemilih masuk ialah rentetan,
jika ( jenis pemilih === "rentetan") {
Jika ( selector.charAt(0) === "<" && selector.charAt( selector.length - 1 ) === ">" && selector.length >= 3 ) {
// Anggap rentetan yang bermula dan berakhir dengan <> ialah HTML dan langkau semakan regex
padanan = [ null, selector, null ];
} lain {
padanan = rquickExpr.exec( pemilih );
}
// Padankan html atau pastikan tiada konteks dinyatakan untuk #id
Jika ( padan && (padan[1] || !konteks) ) {
// PENGENDALI: $(html) -> $(array)
Jika (padankan[1]) {
context = context instanceof jQuery ? context[0] : context;
doc = ( context && context.nodeType ? context.ownerDocument || context : document );
// skrip adalah benar untuk back-compat
Pemilih = jquery.parsehtml (padan [1], dokumen, benar);
If ( rsingleTag.test( match[1] ) && jQuery.isPlainObject( context ) ) {
This.attr.call( pemilih, konteks, benar );
}
Kembalikan jQuery.merge( ini, pemilih );
// PENGENDALI: $(#id)
} lain {
elem = document.getElementById( padanan [2] );
// Semak parentNode untuk menangkap apabila Blackberry 4.6 kembali
// nod yang tiada lagi dalam dokumen #6963
Jika (elem && elem.parentNode) {
// Behandeln Sie den Fall, in dem IE und Opera Elemente zurückgeben
// nach Name statt ID
if ( elem.id !== match[2] ) {
return rootjQuery.find( selector );
}
// Andernfalls fügen wir das Element direkt in das jQuery-Objekt ein
this.length = 1;
this[0] = elem;
}
this.context = document;
this.selector = Selektor;
gib dies zurück;
}
// HANDLE: $(expr, $(...))
} else if ( !context || context.jquery ) {
return ( context || rootjQuery ).find( selector );
// HANDLE: $(expr, context)
// (was genau äquivalent ist zu: $(context).find(expr)
} sonst {
return this.constructor( context ).find( selector );
}
// HANDLE: $(function)
// Verknüpfung für Dokument bereit
// 当selector为function时相当于$(document).ready(selector);
} else if ( jQuery.isFunction( selector ) ) {
return rootjQuery.ready( selector );
}
// 当selector参数为{selector:'#id', context:document}之类时,重置属性selector和context
if ( selector.selector !== undefiniert ) {
this.selector = selector.selector;
this.context = selector.context;
}
return jQuery.makeArray( selector, this );
}
};
以上就是本文的全部内容了,希望大家能够喜欢.