Analyser les instances de fonctions principales dans 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 exemplevar 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 exemplevar 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; };
Regardez comment c'est écrit
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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, 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 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

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 à 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

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 : <

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 :

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 :

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
