Rumah  >  Artikel  >  hujung hadapan web  >  Kaedah lulus parameter untuk inisialisasi_jquery objek jQuery

Kaedah lulus parameter untuk inisialisasi_jquery objek jQuery

WBOY
WBOYasal
2016-05-16 16:12:441225semak imbas

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)

Salin kod Kod adalah seperti berikut:

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 );
    }
};

以上就是本文的全部内容了,希望大家能够喜欢.

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn