Cours dans CoffeeScript
Points de base
- CoffeeScript implémente les systèmes de classe traditionnels, bien que JavaScript lui-même ne le fasse pas. Cela facilite la compréhension des débutants tout en conservant la flexibilité des prototypes pour les programmeurs expérimentés.
- La classe Coffeescript prend en charge l'héritage, permettant la création de sous-classes qui héritent automatiquement des propriétés et des méthodes de leur classe parent. Les sous-classes peuvent également remplacer les fonctions de classe des parents, comme le montre les fonctions "inquiétude" et "profit" dans les sous-classes "sénateur" et "Student".
- Bien que CoffeeScript soit pratique et-concise de syntaxie, il permet toujours des systèmes de prototypes qui implémentent JavaScript, y compris en utilisant "::" comme raccourci vers "Prototype", et en utilisant les mots clés "étend" et "super" pour les constructeurs.
JavaScript n'a pas de systèmes de classe traditionnels, mais utilise des prototypes. Le prototype est très flexible et puissant, mais il est déroutant pour les débutants. Par conséquent, Coffeescript crée un système de classe traditionnel. Mais… comment cela l'a-t-il fait? Le slogan de CoffeeScript est "It's Just JavaScript", et JavaScript n'a évidemment pas le système de classe traditionnel. Dans cet article, nous couvrirons les bases de la création d'une classe CoffeeScript. Dans le prochain article, nous creuserons en JavaScript généré (relativement avancé) pour voir la magie derrière elle.
classe parentNous l'expliquerons principalement à travers des exemples, car pour ceux qui ont lu mon introduction à CoffeeScript, il devrait être facile de comprendre ce qui se passe.
Nous déclarons une classe appelée Bourgeoisie. La déclaration de fonction de la classe est la suivante:
class Bourgeoisie constructor: (@age, @privilegeConstant) -> worry: -> console.log("我的股票下跌了 1%!") profit: (hardWork, luck) -> return (@age - 23) * hardWork * (luck + @privilegeConstant) elite = new Bourgeoisie(29, 397) elite.worry() # "我的股票下跌了 1%!" elite.profit(20, 50) # 53640
Le constructeur est nommé constructeur. Il accepte deux paramètres, l'âge et le privilegeConstant, et les attribue automatiquement sous forme de variables d'instance (@ est un remplacement pour cela dans CoffeeScript, et les variables sont automatiquement attribuées à l'instance lorsqu'elles sont utilisées dans les paramètres du constructeur). Lorsque vous créez une nouvelle bourgeoisie, le constructeur est appelé automatiquement, comme en bas de l'exemple de code. Nous avons deux autres fonctions. La première fonction, l'inquiétude n'accepte aucun paramètre. Le deuxième profit de fonction accepte deux arguments et renvoie un nombre.
functionName: (arguments) -> code
Classe d'héritage
Maintenant, nous voulons un cours qui hérite de la bourgeoisie. Nous le nommons sénateur.
Cette classe
class Senator extends Bourgeoisie worry: -> console.log("民调下跌了 1%!") senator = new Senator(45, 992) senator.worry() # "民调下跌了 1%!" senator.profit(6, 10) # 132264
bourgeoisie, ce qui signifie qu'il a toutes les fonctionnalités de la classe parent. Le constructeur est exactement le même que la fonction de profit , la seule différence est que lors de la construction d'une instance, vous appelez le sénateur au lieu de la bourgeoisie. D'un autre côté, la fonction d'inquiétude est différente. Le sénateur est plus inquiet pour les sondages que les actions, donc son inquiétude couvre l'inquiétude de la classe des parents. Cette remplacement peut être revu dans la classe étudiante illustrée ci-dessous. L'inquiétude de l'élève écrase l'inquiétude de la classe des parents (plus dramatique que la manière du sénateur), et leur profit est également écrasé. Cependant, l'écrasement dépend désormais de la fonction de profit de la classe parent. Il prend cette fonction et moins les frais de scolarité. C'est une période difficile pour les étudiants! Mais ce que vous devriez vraiment en apprendre, c'est le mot-clé Super, qui appelle la version de fonction de la classe parent. Mais, j'aime les prototypes Très bien! Coffeescript est pour vous, mais il vous offre toujours des fonctionnalités puissantes. Utilisons-le! Voici un bref exemple de notre dernière fois: Cela devrait sembler familier, car 90% des changements sont de remplacer certaines fonctions par des flèches pointues. Le prototype du système d'hérédité reste le même car rappelez-vous que CoffeeScript est juste JavaScript. La syntaxe est plus concise, et si vous voulez prototyper le style Brendan Eich que nous avons utilisé la dernière fois, vous n'avez pas besoin d'en savoir plus. Cela ne veut pas dire que CoffeeScript n'applique pas certains raccourcis. Vous pouvez utiliser :: au lieu du prototype. Cependant, dans les prototypes de style Brendan Eich, nous n'avons besoin de l'utiliser qu'une seule fois dans la méthode de l'objet (O). Nous avons également accès aux étendues et à des mots clés super, mais ces mots clés ne sont utilisés que dans le constructeur - nous le cachons à nouveau dans la méthode objet (o). Conclusion Le système d'héritage classique de Coffeescript offre une commodité et un confort aux développeurs ordinaires. De plus, la syntaxe propre de Coffeescript facilite la mise en œuvre d'un réel système de prototype. En bref, il n'y a que des avantages mais pas de mal. FAQ sur la classe CoffeeScript Les classes CoffeeScript sont un concept de base qui aide à organiser et à créer du code. Ils fournissent un moyen de créer des objets avec des propriétés et des méthodes spécifiques. Les classes facilitent la création de structures de données complexes et fournissent un moyen de résumer les données et les fonctionnalités en un seul endroit. Ils prennent également en charge l'héritage, vous permettant de créer une nouvelle classe qui hérite d'une classe existante. Cela peut réduire considérablement la duplication du code et améliorer la maintenabilité du code. Il est simple de définir une classe dans CoffeeScript. Vous utilisez le mot-clé de classe suivi du nom de classe. Par exemple, classe MyClass. Vous pouvez ensuite utiliser le symbole @ pour vous référer à une instance de la classe pour définir les propriétés et les méthodes de la classe. Par exemple, @MyProperty définira les propriétés de la classe, tandis que @MyMethod: - & gt; L'héritage dans CoffeeScript est implémenté à l'aide du mot clé EXTENSE. Lorsque vous définissez une classe, vous pouvez spécifier qu'elle étend une autre classe. Cela signifie que la nouvelle classe héritera de toutes les propriétés et méthodes de la classe qu'elle étend. Par exemple, la classe MySubClass étend MyClass créera une nouvelle classe héritée de MyClass. Oui, vous pouvez remplacer les méthodes dans une sous-classe de CoffeeScript. Lorsque vous définissez une méthode dans une sous-classe qui a le même nom qu'une méthode dans la superclasse, la méthode de la sous-classe est utilisée. Si vous souhaitez toujours appeler la méthode Super Class, vous pouvez utiliser le mot-clé Super. Pour créer une instance d'une classe dans CoffeeScript, vous pouvez utiliser le nouveau mot-clé suivi du nom de classe. Par exemple, MyInstance = new MyClass créera une nouvelle instance de MyClass. La méthode du constructeur dans la classe CoffeeScript est une méthode spéciale qui est appelée lorsqu'une nouvelle instance de la classe est créée. Il est généralement utilisé pour initialiser les propriétés d'une classe. Dans CoffeeScript, la méthode du constructeur est définie à l'aide du mot-clé du constructeur. CoffeeScript ne prend pas en charge les propriétés et les méthodes privées dans l'intégration. Cependant, vous pouvez obtenir des effets similaires en utilisant des fermetures ou en définissant les propriétés et méthodes dans les méthodes de constructeur, ce qui les rend accessibles uniquement dans les cas de la classe. Pour appeler une méthode sur une instance de classe dans CoffeeScript, vous pouvez utiliser l'opérateur. Par exemple, MyInstance.MyMethod () appellera la méthode MyMethod sur l'objet MyInstance. Oui, vous pouvez ajouter des propriétés et des méthodes à la classe après avoir défini la classe dans CoffeeScript. Vous pouvez le faire en les définissant sur le prototype de la classe. Par exemple, myClass :: myNewMethod = - & gt; Pour vérifier le type d'une instance de classe dans CoffeeScript, vous pouvez utiliser l'opérateur d'instance. Par exemple, l'instance MyInstance de MyClass renvoie True si MyInstance est une instance de MyClass. 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!class Bourgeoisie
constructor: (@age, @privilegeConstant) ->
worry: ->
console.log("我的股票下跌了 1%!")
profit: (hardWork, luck) ->
return (@age - 23) * hardWork * (luck + @privilegeConstant)
elite = new Bourgeoisie(29, 397)
elite.worry() # "我的股票下跌了 1%!"
elite.profit(20, 50) # 53640
functionName: (arguments) ->
code
Quelle est la signification d'une classe dans CoffeeScript?
Comment définir une classe dans CoffeeScript?
Comment fonctionne l'héritage de la classe CoffeeScript?
Puis-je remplacer la méthode dans une sous-classe de CoffeeScript?
Comment créer une instance d'une classe dans CoffeeScript?
Quel est le but des méthodes de constructeur dans la classe CoffeeScript?
Puis-je définir des propriétés et des méthodes privées dans la classe CoffeeScript?
Comment appeler une méthode sur une instance de classe dans CoffeeScript?
Puis-je ajouter des propriétés et des méthodes à la classe après avoir défini la classe dans CoffeeScript?
Comment vérifier le type d'une instance de classe dans CoffeeScript?

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

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

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)

Sujets chauds











Des questions et des solutions fréquemment posées pour l'impression de billets thermiques frontaux pour le développement frontal, l'impression de billets est une exigence commune. Cependant, de nombreux développeurs mettent en œuvre ...

JavaScript est la pierre angulaire du développement Web moderne, et ses principales fonctions incluent la programmation axée sur les événements, la génération de contenu dynamique et la programmation asynchrone. 1) La programmation axée sur les événements permet aux pages Web de changer dynamiquement en fonction des opérations utilisateur. 2) La génération de contenu dynamique permet d'ajuster le contenu de la page en fonction des conditions. 3) La programmation asynchrone garantit que l'interface utilisateur n'est pas bloquée. JavaScript est largement utilisé dans l'interaction Web, les applications à une page et le développement côté serveur, améliorant considérablement la flexibilité de l'expérience utilisateur et du développement multiplateforme.

Il n'y a pas de salaire absolu pour les développeurs Python et JavaScript, selon les compétences et les besoins de l'industrie. 1. Python peut être davantage payé en science des données et en apprentissage automatique. 2. JavaScript a une grande demande dans le développement frontal et complet, et son salaire est également considérable. 3. Les facteurs d'influence comprennent l'expérience, la localisation géographique, la taille de l'entreprise et les compétences spécifiques.

La discussion sur la réalisation des effets de défilement de parallaxe et d'animation des éléments dans cet article explorera comment réaliser le site officiel de Shiseido (https://www.shiseido.co.jp/sb/wonderland/) ...

Apprendre JavaScript n'est pas difficile, mais c'est difficile. 1) Comprendre les concepts de base tels que les variables, les types de données, les fonctions, etc. 2) Master la programmation asynchrone et les implémenter via des boucles d'événements. 3) Utilisez les opérations DOM et promettez de gérer les demandes asynchrones. 4) Évitez les erreurs courantes et utilisez des techniques de débogage. 5) Optimiser les performances et suivre les meilleures pratiques.

Les dernières tendances de JavaScript incluent la montée en puissance de TypeScript, la popularité des frameworks et bibliothèques modernes et l'application de WebAssembly. Les prospects futurs couvrent des systèmes de type plus puissants, le développement du JavaScript côté serveur, l'expansion de l'intelligence artificielle et de l'apprentissage automatique, et le potentiel de l'informatique IoT et Edge.

Comment fusionner les éléments du tableau avec le même ID dans un seul objet en JavaScript? Lors du traitement des données, nous rencontrons souvent la nécessité d'avoir le même ID ...

Explorez la mise en œuvre de la fonction de glisser et de réglage du panneau de type VScode dans le frontal. Dans le développement frontal, comment implémenter un VScode comme ...
