


Aujourd'hui, nous avons décidé d'utiliser les fonctions fléchées exclusivement au travail.
Nous avons une configuration ESLint commune et l'équipe a voté pour unifier cette règle dans tous les projets.
Et honnêtement, je ne suis pas fan de cette règle particulière
Personnellement... les déclarations de fonctions semblent plus expressives, du moins pour les symboles de niveau supérieur :
quelque-écran-de-mon-app.tsx
import {} ... export function SomeScreen(props: Props) { const { myContext } = useMyContext() const [state, setState] = useState() const doSomething = () => { ... } const handleSomething = () => { ... } return ...> } function SomeInternalComponent() { ... }
C'est ainsi que j'ai l'habitude d'écrire des composants : déclarer une fonction ressemble à un titre de chapitre dans un roman.
function Chapter3(storySoFar: Props) { // where the Hero meets the Villain }
Mais je comprends le besoin de l'équipe : selon l'auteur original d'un module, nous pourrions trouver au premier niveau const () => {} ou fonction.
L'argument principal est que "les fonctions fléchées sont plus lisibles" (avec lequel je ne suis pas d'accord)
import {} ... const SomeInternalComponent = () => { ... } export const SomeScreen = (props: Props) => { const { myContext } = useMyContext() const [state, setState] = useState() const doSomething = () => { ... } const handleSomething = () => { ... } return ...> }
J'ai essayé de trouver un avantage technique pour soutenir ma préférence... un nerd *pitimini* [ quelque chose de petit ou d'insignifiant ] qui fait pencher la balance à mon avantage mais comme nous tous sont d'accord sur ce qui suit :
- Pas de cours (juste des fonctions)
- Pas de trucs globaux (modules modernes)
- Non ça
Il n'y a pas de différences significatives entre chacun.
Plonger dans les détails :
const foo = () => { ... }
- Pas de levage
- le nom de la fonction est dérivé du nom de la variable ("foo")
- Ne peut pas être écrasé plus tard comme foo=...
- Ne crée pas l'objet prototype foo.prototype
- Ne peut pas être utilisé comme constructeur new foo()
- N'a pas d'arguments
- cette valeur est définie par où la fonction est déclarée
fonction foo() { ... }
- Levage
- le nom de la fonction est évident.
- Peut être écrasé comme foo = ...
- Crée le prototype d'objet foo.prototype
- new est autorisé comme : new foo() (qui relierait le prototype)
- cette valeur est définie par comment la fonction est appelée
En fin de compte, je préfère la Clarté supérieure de la fonction pour les composants de haut niveau, mais la volonté du plus grand nombre prévaut.
Je plaisante, je vais m'adapter. Avoir un style unifié aidera à maintenir une base de code cohérente.
???.
merci d'avoir lu
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!

Explication détaillée de la méthode de remplacement de la chaîne JavaScript et de la FAQ Cet article explorera deux façons de remplacer les caractères de chaîne dans JavaScript: le code JavaScript interne et le HTML interne pour les pages Web. Remplacer la chaîne dans le code JavaScript Le moyen le plus direct consiste à utiliser la méthode Remplace (): str = str.replace ("trouver", "remplacer"); Cette méthode remplace uniquement la première correspondance. Pour remplacer toutes les correspondances, utilisez une expression régulière et ajoutez le drapeau global G: str = str.replace (/ fi

Ce tutoriel vous montre comment intégrer une API de recherche Google personnalisée dans votre blog ou site Web, offrant une expérience de recherche plus raffinée que les fonctions de recherche de thème WordPress standard. C'est étonnamment facile! Vous pourrez restreindre les recherches à Y

Vous voici donc, prêt à tout savoir sur cette chose appelée Ajax. Mais qu'est-ce que c'est exactement? Le terme Ajax fait référence à un regroupement lâche de technologies utilisées pour créer un contenu Web interactif dynamique. Le terme Ajax, inventé à l'origine par Jesse J

Cette série d'articles a été réécrite à la mi-2017 avec des informations à jour et de nouveaux exemples. Dans cet exemple JSON, nous examinerons comment nous pouvons stocker des valeurs simples dans un fichier à l'aide du format JSON. En utilisant la notation de paire de valeurs clés, nous pouvons stocker n'importe quel type

Améliorez votre présentation de code: 10 surligneurs de syntaxe pour les développeurs Partager des extraits de code sur votre site Web ou votre blog est une pratique courante pour les développeurs. Le choix du bon surligneur de syntaxe peut améliorer considérablement la lisibilité et l'attrait visuel. T

Tirez parti de jQuery pour les dispositions de page Web sans effort: 8 plugins essentiels JQuery simplifie considérablement la mise en page de la page Web. Cet article met en évidence huit puissants plugins jQuery qui rationalisent le processus, particulièrement utile pour la création de sites Web manuels

Cet article présente une sélection organisée de plus de 10 didacticiels sur les cadres JavaScript et JQuery Model-View-Controller (MVC), parfait pour augmenter vos compétences en développement Web au cours de la nouvelle année. Ces tutoriels couvrent une gamme de sujets, de Foundatio

Points de base Ceci dans JavaScript fait généralement référence à un objet qui "possède" la méthode, mais cela dépend de la façon dont la fonction est appelée. Lorsqu'il n'y a pas d'objet actuel, cela fait référence à l'objet global. Dans un navigateur Web, il est représenté par Window. Lorsque vous appelez une fonction, cela maintient l'objet global; mais lors de l'appel d'un constructeur d'objets ou de l'une de ses méthodes, cela fait référence à une instance de l'objet. Vous pouvez modifier le contexte de ceci en utilisant des méthodes telles que Call (), Appliquer () et Bind (). Ces méthodes appellent la fonction en utilisant la valeur et les paramètres donnés. JavaScript est un excellent langage de programmation. Il y a quelques années, cette phrase était


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

Version Mac de WebStorm
Outils de développement JavaScript utiles

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

Dreamweaver CS6
Outils de développement Web visuel

Télécharger la version Mac de l'éditeur Atom
L'éditeur open source le plus populaire

SublimeText3 version anglaise
Recommandé : version Win, prend en charge les invites de code !
