Maison interface Web js tutoriel Trois façons de définir des fonctions en js

Trois façons de définir des fonctions en js

Jun 15, 2018 pm 03:59 PM
js 函数

Tutoriel série js 4 fonctions, paramètres de fonction

En js, la fonction elle-même est un type d'objet , il peut donc être défini, attribué, utilisé comme attribut d'un objet ou paramètre d'autres fonctions. Le nom de la fonction est simplement une référence à la classe d'objet de la fonction.

1. Définition de la fonction

[1] L'instruction de déclaration de fonction
utilise le mot-clé function, suivi d'un ensemble de paramètres et du corps de la fonction

function funcname([arg1 [,arg2 [...,argn]]]){
    statement;
}
Copier après la connexion

【2】Expression de définition de fonction

Une fonction définie en mode expression, le nom de la fonction est facultatif

var functionName = function([arg1 [,arg2 [...,argn]]]){
    statement;
}var functionName = function funcName([arg1 [,arg2 [...,argn]]]){
    statement;
}
Copier après la connexion

La fonction anonyme (fonction anonyme) est également appelée lambda Une fonction est une fonction sans identifiant après le mot-clé function

De manière générale, aucun nom n'est requis lors de la définition de fonctions dans des expressions, ce qui rend le code qui les définit plus compact. Les expressions de définition de fonction sont particulièrement adaptées pour définir des fonctions qui ne seront utilisées qu'une seule fois

var tensquared = (function(x) {return x*x;}(10));   //
Copier après la connexion

Alors qu'une expression de définition de fonction contient un nom, la portée locale de la fonction contiendra un nom lié à l'objet fonction. En fait, le nom de la fonction deviendra une variable locale à l'intérieur de la fonction

var test = function fn(){   return fn;
}console.log(test);//fn(){return fn;}console.log(test());//fn(){return fn;}console.log(test()());//fn(){return fn;}
Copier après la connexion

Compréhension personnelle, pour les expressions de fonction nommées, le nom de la fonction est équivalent au paramètre formel de l'objet fonction, qui ne peut être utilisé à l'intérieur de la fonction Use; et le nom de la variable est équivalent au paramètre réel de l'objet fonction, qui peut être utilisé à la fois à l'intérieur et à l'extérieur de la fonction

var test = function fn(){   return fn === test;
}console.log(test());//trueconsole.log(test === fn);//ReferenceError: fn is not defined
Copier après la connexion

La fonction définit un attribut de nom non standard , par lequel la fonction donnée est accessible Le nom spécifié. La valeur de cet attribut est toujours égale à l'identifiant qui suit le mot-clé function L'attribut name de la fonction anonyme est vide

//IE11-浏览器无效,均输出undefined//chrome在处理匿名函数的name属性时有问题,会显示函数表达式的名字function fn(){};
console.log(fn.name);//'fn'var fn = function(){};
console.log(fn.name);//'',在chrome浏览器中会显示'fn'var fn = function abc(){};
console.log(fn.name);//'abc'
Copier après la connexion

[3] Constructeur de fonction

Constructeur de fonction La fonction reçoit un nombre quelconque de paramètres, mais le dernier paramètre est toujours considéré comme le corps de la fonction, tandis que les paramètres précédents énumèrent les paramètres de la nouvelle fonction

var functionName = new Function(['arg1' [,'arg2' [...,'argn']]],'statement;');
Copier après la connexion

[Note] Le constructeur Function ne peut pas être spécifié Nom de fonction, il crée une fonction anonyme

Techniquement, il s'agit d'une expression de fonction. Cependant, cela n’est pas recommandé car cette syntaxe entraîne une analyse double du code. La première fois consiste à analyser le code javascript normal, et la deuxième fois consiste à analyser la chaîne passée dans le constructeur, ce qui affecte les performances

var sum = new Function('num1','num2','return num1 + num2');//等价于var sum = function(num1,num2){
    return num1+num2;
}
Copier après la connexion

Pour les fonctions créées par le constructeur Function(), la compilation de son corps de fonction s'exécutera toujours dans une portée globale. Par conséquent, le constructeur Function() est similaire à eval() exécuté dans la portée globale

var test = 0;function fn(){
    var test = 1;    return new Function('return test');}
console.log(fn()());//0
Copier après la connexion

[Note] Toutes les fonctions ne peuvent pas devenir des constructeurs

var o = new Math.min();//Uncaught TypeError: Math.min is not a constructor
Copier après la connexion

2. Ordre de déclaration des fonctions

Les déclarations de fonctions seront chargées en premier par rapport aux variables. Ne vous inquiétez donc pas de savoir si la déclaration de fonction est avant ou après l'appel.

Lors de l'appel d'une fonction, elle interrogera d'abord l'objet actif local, c'est-à-dire dans le fichier js actuel, s'il n'y a pas de requête, elle interrogera donc vers le haut, si le même nom de fonction est défini. dans deux fichiers js, les deux js Les fonctions respectives sont appelées à l'intérieur du fichier, et la dernière fonction déclarée est appelée dans d'autres fichiers js.

3.

Les déclarations répétées de variables sont inutiles et n'écraseront pas les variables précédemment déclarées dans la même portée, mais les déclarations répétées de fonctions écraseront les déclarations de fonction précédentes. ou une variable du même nom.

//变量的重复声明无用var a = 1;var a;
console.log(a);//1
Copier après la connexion
//覆盖同名变量var a;function a(){
    console.log(1);
}a();//1
Copier après la connexion
//覆盖同名函数a();//2function a(){
    console.log(1);
}function a(){
    console.log(2);
}
Copier après la connexion

4. Supprimer les variables créées par

l'instruction de déclaration de fonction ne peut pas être supprimée, c'est la même chose que la déclaration de variable.

function foo(){
    console.log(1);
}delete foo;//falseconsole.log(foo());//1
Copier après la connexion

Cet article présente trois façons de définir des fonctions en js. Pour plus de contenu connexe, veuillez faire attention au site Web chinois php.

Recommandations associées :

« Vrai et faux » en JS

Comment déterminer une collision via JS !

Présentation de quelques solutions d'implémentation js pour les algorithmes classiques

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)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines 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)

Conseils pour créer dynamiquement de nouvelles fonctions dans les fonctions Golang Conseils pour créer dynamiquement de nouvelles fonctions dans les fonctions Golang Apr 25, 2024 pm 02:39 PM

Le langage Go propose deux technologies de création de fonctions dynamiques : la fermeture et la réflexion. les fermetures permettent d'accéder aux variables dans la portée de la fermeture, et la réflexion peut créer de nouvelles fonctions à l'aide de la fonction FuncOf. Ces technologies sont utiles pour personnaliser les routeurs HTTP, mettre en œuvre des systèmes hautement personnalisables et créer des composants enfichables.

Considérations relatives à l'ordre des paramètres dans la dénomination des fonctions C++ Considérations relatives à l'ordre des paramètres dans la dénomination des fonctions C++ Apr 24, 2024 pm 04:21 PM

Dans la dénomination des fonctions C++, il est crucial de prendre en compte l’ordre des paramètres pour améliorer la lisibilité, réduire les erreurs et faciliter la refactorisation. Les conventions courantes d'ordre des paramètres incluent : action-objet, objet-action, signification sémantique et conformité de la bibliothèque standard. L'ordre optimal dépend de l'objectif de la fonction, des types de paramètres, de la confusion potentielle et des conventions du langage.

Comment écrire des fonctions efficaces et maintenables en Java ? Comment écrire des fonctions efficaces et maintenables en Java ? Apr 24, 2024 am 11:33 AM

La clé pour écrire des fonctions Java efficaces et maintenables est la suivante : restez simple. Utilisez un nom significatif. Gérer des situations particulières. Utilisez une visibilité appropriée.

Collection complète de formules de fonctions Excel Collection complète de formules de fonctions Excel May 07, 2024 pm 12:04 PM

1. La fonction SOMME permet de sommer les nombres d'une colonne ou d'un groupe de cellules, par exemple : =SOMME(A1:J10). 2. La fonction MOYENNE permet de calculer la moyenne des nombres dans une colonne ou un groupe de cellules, par exemple : =AVERAGE(A1:A10). 3. Fonction COUNT, utilisée pour compter le nombre de nombres ou de texte dans une colonne ou un groupe de cellules, par exemple : =COUNT(A1:A10) 4. Fonction IF, utilisée pour effectuer des jugements logiques basés sur des conditions spécifiées et renvoyer le résultat correspondant.

Comparaison des avantages et des inconvénients des paramètres par défaut et des paramètres variables des fonctions C++ Comparaison des avantages et des inconvénients des paramètres par défaut et des paramètres variables des fonctions C++ Apr 21, 2024 am 10:21 AM

Les avantages des paramètres par défaut dans les fonctions C++ incluent la simplification des appels, l’amélioration de la lisibilité et l’évitement des erreurs. Les inconvénients sont une flexibilité limitée et des restrictions de dénomination. Les avantages des paramètres variadiques incluent une flexibilité illimitée et une liaison dynamique. Les inconvénients incluent une plus grande complexité, des conversions de types implicites et des difficultés de débogage.

Quels sont les avantages des fonctions C++ renvoyant des types référence ? Quels sont les avantages des fonctions C++ renvoyant des types référence ? Apr 20, 2024 pm 09:12 PM

Les avantages des fonctions renvoyant des types référence en C++ incluent : Améliorations des performances : le passage par référence évite la copie d'objets, économisant ainsi de la mémoire et du temps. Modification directe : L'appelant peut modifier directement l'objet de référence renvoyé sans le réaffecter. Simplicité du code : le passage par référence simplifie le code et ne nécessite aucune opération d'affectation supplémentaire.

Quelle est la différence entre les fonctions PHP personnalisées et les fonctions prédéfinies ? Quelle est la différence entre les fonctions PHP personnalisées et les fonctions prédéfinies ? Apr 22, 2024 pm 02:21 PM

La différence entre les fonctions PHP personnalisées et les fonctions prédéfinies est la suivante : Portée : les fonctions personnalisées sont limitées à la portée de leur définition, tandis que les fonctions prédéfinies sont accessibles tout au long du script. Comment définir : les fonctions personnalisées sont définies à l'aide du mot-clé function, tandis que les fonctions prédéfinies sont définies par le noyau PHP. Passage de paramètres : les fonctions personnalisées reçoivent des paramètres, tandis que les fonctions prédéfinies peuvent ne pas nécessiter de paramètres. Extensibilité : des fonctions personnalisées peuvent être créées selon les besoins, tandis que les fonctions prédéfinies sont intégrées et ne peuvent pas être modifiées.

Exception de fonction C++ avancée : gestion personnalisée des erreurs Exception de fonction C++ avancée : gestion personnalisée des erreurs May 01, 2024 pm 06:39 PM

La gestion des exceptions en C++ peut être améliorée grâce à des classes d'exceptions personnalisées qui fournissent des messages d'erreur spécifiques, des informations contextuelles et effectuent des actions personnalisées en fonction du type d'erreur. Définissez une classe d'exception héritée de std::exception pour fournir des informations d'erreur spécifiques. Utilisez le mot-clé throw pour lancer une exception personnalisée. Utilisez Dynamic_cast dans un bloc try-catch pour convertir l'exception interceptée en un type d'exception personnalisé. Dans le cas réel, la fonction open_file lève une exception FileNotFoundException. La capture et la gestion de l'exception peuvent fournir un message d'erreur plus spécifique.

See all articles