Maison interface Web js tutoriel Analyser les instances de fonctions principales dans jquery

Analyser les instances de fonctions principales dans jquery

Jun 17, 2017 pm 05:49 PM
jquery 深度 解析

Les fonctions de base incluent :

Comment jquery est défini, comment l'appeler et comment l'étendre. Maîtriser la manière dont les méthodes principales sont implémentées est la clé pour comprendre le code source de jQuery. Ici, tout est devenu soudain clair.

1, comment définir, c'est-à-dire l'entrée

// Définir une copie locale de jQuery

var jQuery = function( selector, context ) {

// L'objet jQuery est en fait juste le constructeur d'initialisation 'amélioré'

return new jQuery.fn.init( selector, context, rootjQuery ); // L'objet jQuery est en fait juste la fonction constructeur jQuery.prototype.init version améliorée

}

2, prototype jQuery et sa relation avec jQuery.fn.init

//Définissez la méthode objet, c'est-à-dire qu'elle ne peut être appelée que via $("xx").

jQuery.fn = jQuery.prototype = {

init:function( sélecteur, contexte, rootjQuery ) {

return jQuery.makeArray( sélecteur, this );

>

Il existe de nombreux autres attributs et méthodes,

Les attributs incluent : jquery, constructeur, sélecteur, longueur

Les méthodes incluent : toArray,get, pushStack,each, ready,slice, first,last,eq, map,end, push, sort, splice

}

// jQuery .prototype est attribué à jQuery.prototype.init.prototype pour une instanciation ultérieure

// Donner à la fonction init le prototype jQuery pour une instanciation ultérieure

jQuery.fn.init.prototype = jQuery.fn ;

Autrement dit, $("xx") a une méthode d'instance et peut être appelée. (Appelez la méthode définie sous jQuery.prototype)

Pourquoi jQuery renvoie-t-il l'objet jQuery.fn.init ?

jQuery = function( selector, context ) {

/ / L'objet jQuery n'est en fait que le constructeur d'initialisation 'amélioré'

return new jQuery.fn.init( selector, context, rootjQuery );

}

jQuery.fn = jQuery.prototype = {



}

jQuery.fn.init.prototype = jQuery.fn;

Trouver des questions similaires sur stackoverflow :

http://stackoverflow.com/questions/4754560/help-understanding-jquerys-jquery-fn-init-why-is-init-in-fn

Et ça

http://stackoverflow.com/questions/1856890/why-does-jquery-use-new-jquery-fn-init-for-creating-jquery-object-but-i-can/1858537#1858537

Je crois que le code est écrit de cette façon afin que le nouveau mot-clé ne soit pas requis à chaque fois que vous instanciez un nouvel objet jQuery et également pour déléguer la logique derrière la construction de l'objet au prototype. le nettoyeur de bibliothèque à utiliser et ce dernier pour conserver la logique d'initialisation proprement au même endroit et permettre à init d'être appelé de manière récursive pour construire et renvoyer un objet qui correspond correctement aux arguments passés.

3, étendre étendu méthode objet et principe de méthode statique

jQuery.extend = jQuery.fn.extend = function() {

var target = arguments[0] ||

return target;

}

Il est pratique d'utiliser extend, qui n'est rien de plus que $.extend({}); Si vous, ce serait formidable si vous pouviez comprendre et penser à jQuery.prototype lorsque vous voyez fn.

Regardez à nouveau cette portée :

$.extend -> ceci est $-> this.aa()

$.fn.extend-> ;this is $.fn-> this.aa()

Vous trouverez ci-joint les détails de l'implémentation de l'extension :

Scénarios d'utilisation :

1, étendez certaines fonctions

Un seul paramètre. Par exemple : $.extend({f1:function(){},f2:function(){},f3:function(){}})

2, fusionne plusieurs objets dans le premier objet

(1) Copie superficielle, le premier paramètre est l'objet cible. Par exemple

var a = {name:”hello”}

var b = {age:30}

$.extend(a,b);//a = {name:”hello”,age:30}

(2) Copie complète, le premier paramètre est VRAI et le deuxième paramètre est l'objet cible. Par exemple

var a = {name:{job:”it”}};


var b = {name:{age: 30 }};

// $ .extend(a,b);

$.extend(true,a,b);

console.log(a);

jQuery.extend = jQuery.fn.extend = function() {
    var options, name, src, copy, copyIsArray, clone,
        target = arguments[0] || {},
        i = 1,
        length = arguments.length,
        deep = false;

    // 是不是深复制  Handle a deep copy situation
    if ( typeof target === "boolean" ) {
        deep = target;
        target = arguments[1] || {};
        // skip the boolean and the target
        i = 2;
    }

    // 不是对象类型  Handle case when target is a string or something (possible in deep copy)
    if ( typeof target !== "object" && !jQuery.isFunction(target) ) {
        target = {};
    }

    // 扩展插件的情况  extend jQuery itself if only one argument is passed
    if ( length === i ) {//$.extend({f1:function(){},f2:function(){},f3:function(){}})
        target = this;//this是$,或是$.fn
        --i;
    }

    for ( ; i < length; i++ ) {//可能有多个对象扩展到第一个对象上
        // Only deal with non-null/undefined values
        if ( (options = arguments[ i ]) != null ) {//options是一个对象
            // Extend the base object
            for ( name in options ) {
                src = target[ name ];  //src是target里已经存在的value(也可能不存在)
                copy = options[ name ];//copy是待合入的一个value

                // 防止循环引用  Prevent never-ending loop
                if ( target === copy ) {//例如:var a={};$.extend(a,{name:a});//可能导致循环引用
                    continue;
                }

                // if是深复制else是浅复制  Recurse if we're merging plain objects or arrays
                if ( deep && copy && ( jQuery.isPlainObject(copy) || (copyIsArray = jQuery.isArray(copy)) ) ) {
                    if ( copyIsArray ) {
                        copyIsArray = false;
                        clone = src && jQuery.isArray(src) ? src : [];

                    } else {
                        clone = src && jQuery.isPlainObject(src) ? src : {};
                    }

                    // 亮了,直至剥离至最深一层非对象类型,而且是逐个。Never move original objects, clone them
                    target[ name ] = jQuery.extend( deep, clone, copy );

                // Don't bring in undefined values
                } else if ( copy !== undefined ) {
                    target[ name ] = copy;//target[ name ] = options[ name ];
                }
            }
        }
    }

    // Return the modified object
    return target;
};
Copier après la connexion
jQuery.extend({…}) Analyse


Regardez comment c'est écrit

jQuery.extend({

prop:””

méthode : function(){}

});

On peut voir que ces méthodes sont des propriétés statiques et des méthodes de jQuery (c'est-à-dire des méthodes outils), qui peuvent être directement fournies aux utilisateurs à l’avenir. Peut également être utilisé en interne.

Les attributs et méthodes spécifiques des outils implémentés sont (également marqués ceux qui sont utilisés en interne)

jQuery.extend({

expando : Générer une chaîne JQ unique(interne)

noConflict() : Prévenir les conflits

isReady : Si le DOM est chargé (interne)

readyWait : Compteur du nombre de fichiers à attendre (interne)

holdReady() : Report du déclenchement du DOM

ready() : Préparez le déclenchement DOM

isFunction() : Si c'est une fonction

isArray() : Que ce soit un tableau

isWindow() : Que ce soit une fenêtre

isNumeric() : Is it Number

type() : Détermine le type de données de

isPlainObject() : S'il s'agit d'un argument d'objet

isEmptyObject() : S'il s'agit d'un objet vide

error() : Lance une exception

parseHTML() : Analyser le nœud

parseJSON() : Parse JSON

par seXML () : Parse XML

noop() : Fonction vide

globalEval() : Analyse globale JS

camelCase() : Convertir le cas de chameau

nodeName ( ) : S'il s'agit du nom de nœud spécifié (interne)

each() : Parcourir la collection

trim() : Supprimer les espaces de début et de fin

makeArray() : Convertir un tableau de type tableau en tableau réel

inArray() : Version du tableau indexOf

merge() : Fusionner les tableaux

grep() : Filtrer le nouveau tableau

map() : Mapper le nouveau tableau

guid : Identifiant unique (interne)

proxy() : Changez ceci pointer vers

access() : Opération de valeur multifonction (interne)

now() : Heure actuelle

swap() : CSS swap (interne)

});

jQuery.ready.promise = function(){}; Surveillance du fonctionnement asynchrone du DOM (interne)

function isArraylike(){} Jugement de type tableau ( interne)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Explication détaillée de l'erreur Oracle 3114 : comment la résoudre rapidement Explication détaillée de l'erreur Oracle 3114 : comment la résoudre rapidement Mar 08, 2024 pm 02:42 PM

Explication détaillée de l'erreur Oracle 3114 : Comment la résoudre rapidement, des exemples de code spécifiques sont nécessaires Lors du développement et de la gestion de la base de données Oracle, nous rencontrons souvent diverses erreurs, parmi lesquelles l'erreur 3114 est un problème relativement courant. L'erreur 3114 indique généralement un problème avec la connexion à la base de données, qui peut être provoqué par une défaillance du réseau, un arrêt du service de base de données ou des paramètres de chaîne de connexion incorrects. Cet article expliquera en détail la cause de l'erreur 3114 et comment résoudre rapidement ce problème, et joindra le code spécifique.

Analyse de la signification et de l'utilisation du point médian en PHP Analyse de la signification et de l'utilisation du point médian en PHP Mar 27, 2024 pm 08:57 PM

[Analyse de la signification et de l'utilisation du point médian PHP] En PHP, le point médian (.) est un opérateur couramment utilisé, utilisé pour connecter deux chaînes ou propriétés ou méthodes d'objets. Dans cet article, nous approfondirons la signification et l’utilisation des points médians en PHP, en les illustrant avec des exemples de code concrets. 1. Opérateur de point médian de chaîne de connexion L’utilisation la plus courante en PHP consiste à connecter deux chaînes. En plaçant . entre deux chaînes, vous pouvez les assembler pour former une nouvelle chaîne. $string1=&qu

Parsing Wormhole NTT : un framework ouvert pour n'importe quel jeton Parsing Wormhole NTT : un framework ouvert pour n'importe quel jeton Mar 05, 2024 pm 12:46 PM

Wormhole est un leader en matière d'interopérabilité blockchain, axé sur la création de systèmes décentralisés résilients et évolutifs qui donnent la priorité à la propriété, au contrôle et à l'innovation sans autorisation. Le fondement de cette vision est un engagement envers l'expertise technique, les principes éthiques et l'alignement de la communauté pour redéfinir le paysage de l'interopérabilité avec simplicité, clarté et une large suite de solutions multi-chaînes. Avec l’essor des preuves sans connaissance, des solutions de mise à l’échelle et des normes de jetons riches en fonctionnalités, les blockchains deviennent plus puissantes et l’interopérabilité devient de plus en plus importante. Dans cet environnement d’applications innovant, de nouveaux systèmes de gouvernance et des capacités pratiques offrent des opportunités sans précédent aux actifs du réseau. Les créateurs de protocoles se demandent désormais comment opérer dans ce nouveau marché multi-chaînes.

Analyse des nouvelles fonctionnalités de Win11 : Comment ignorer la connexion au compte Microsoft Analyse des nouvelles fonctionnalités de Win11 : Comment ignorer la connexion au compte Microsoft Mar 27, 2024 pm 05:24 PM

Analyse des nouvelles fonctionnalités de Win11 : Comment ignorer la connexion à un compte Microsoft Avec la sortie de Windows 11, de nombreux utilisateurs ont constaté qu'il apportait plus de commodité et de nouvelles fonctionnalités. Cependant, certains utilisateurs n'aiment pas que leur système soit lié à un compte Microsoft et souhaitent ignorer cette étape. Cet article présentera quelques méthodes pour aider les utilisateurs à ne pas se connecter à un compte Microsoft dans Windows 11 afin d'obtenir une expérience plus privée et autonome. Tout d’abord, comprenons pourquoi certains utilisateurs hésitent à se connecter à leur compte Microsoft. D'une part, certains utilisateurs craignent

Conseils jQuery : modifiez rapidement le texte de toutes les balises a de la page Conseils jQuery : modifiez rapidement le texte de toutes les balises a de la page Feb 28, 2024 pm 09:06 PM

Titre : jQuery Astuces : Modifier rapidement le texte de toutes les balises a de la page En développement web, nous avons souvent besoin de modifier et d'exploiter des éléments de la page. Lorsque vous utilisez jQuery, vous devez parfois modifier le contenu textuel de toutes les balises de la page en même temps, ce qui peut économiser du temps et de l'énergie. Ce qui suit explique comment utiliser jQuery pour modifier rapidement le texte de toutes les balises a de la page et donne des exemples de code spécifiques. Tout d'abord, nous devons introduire le fichier de la bibliothèque jQuery et nous assurer que le code suivant est introduit dans la page : &lt

Utilisez jQuery pour modifier le contenu textuel de toutes les balises Utilisez jQuery pour modifier le contenu textuel de toutes les balises Feb 28, 2024 pm 05:42 PM

Titre : utilisez jQuery pour modifier le contenu textuel de toutes les balises. jQuery est une bibliothèque JavaScript populaire largement utilisée pour gérer les opérations DOM. En développement web, nous rencontrons souvent le besoin de modifier le contenu textuel de la balise de lien (une balise) sur la page. Cet article expliquera comment utiliser jQuery pour atteindre cet objectif et fournira des exemples de code spécifiques. Tout d’abord, nous devons introduire la bibliothèque jQuery dans la page. Ajoutez le code suivant dans le fichier HTML :

Apache2 ne peut pas analyser correctement les fichiers PHP Apache2 ne peut pas analyser correctement les fichiers PHP Mar 08, 2024 am 11:09 AM

En raison de contraintes d'espace, voici un bref article : Apache2 est un logiciel de serveur Web couramment utilisé et PHP est un langage de script côté serveur largement utilisé. Lors du processus de création d'un site Web, vous rencontrez parfois le problème qu'Apache2 ne peut pas analyser correctement le fichier PHP, ce qui entraîne l'échec de l'exécution du code PHP. Ce problème est généralement dû au fait qu'Apache2 ne configure pas correctement le module PHP ou que le module PHP est incompatible avec la version d'Apache2. Il existe généralement deux manières de résoudre ce problème :

Comparaison des bibliothèques Java pour l'analyse XML : trouver la meilleure solution Comparaison des bibliothèques Java pour l'analyse XML : trouver la meilleure solution Mar 09, 2024 am 09:10 AM

Introduction XML (Extensible Markup Language) est un format populaire pour stocker et transmettre des données. L'analyse XML en Java est une tâche nécessaire pour de nombreuses applications, de l'échange de données au traitement de documents. Pour analyser efficacement XML, les développeurs peuvent utiliser diverses bibliothèques Java. Cet article comparera certaines des bibliothèques d'analyse XML les plus populaires, en se concentrant sur leurs caractéristiques, fonctionnalités et performances pour aider les développeurs à faire un choix éclairé. Bibliothèque d'analyse DOM (Document Object Model) JavaXMLDOMAPI : une implémentation DOM standard fournie par Oracle. Il fournit un modèle objet qui permet aux développeurs d'accéder et de manipuler des documents XML. DocumentBuilderFactoryfactory=D

See all articles