recherche
Maisoninterface Webjs tutorielCours dans CoffeeScript

Classes in 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 parent

Nous 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
étend

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.

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

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:

functionName: (arguments) ->
  code

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

Quelle est la signification d'une classe dans 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.

Comment définir une classe dans CoffeeScript?

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;

Comment fonctionne l'héritage de la classe CoffeeScript?

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.

Puis-je remplacer la méthode dans une sous-classe de CoffeeScript?

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.

Comment créer une instance d'une classe dans CoffeeScript?

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.

Quel est le but des méthodes de constructeur dans la classe CoffeeScript?

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.

Puis-je définir des propriétés et des méthodes privées dans la classe CoffeeScript?

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.

Comment appeler une méthode sur une instance de classe dans CoffeeScript?

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.

Puis-je ajouter des propriétés et des méthodes à la classe après avoir défini la classe dans CoffeeScript?

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;

Comment vérifier le type d'une instance de classe dans CoffeeScript?

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!

Déclaration
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
Frameworks javascript: alimenter le développement Web moderneFrameworks javascript: alimenter le développement Web moderneMay 02, 2025 am 12:04 AM

La puissance du cadre JavaScript réside dans la simplification du développement, l'amélioration de l'expérience utilisateur et les performances des applications. Lorsque vous choisissez un cadre, considérez: 1. Taille et complexité du projet, 2. Expérience d'équipe, 3. Écosystème et soutien communautaire.

La relation entre JavaScript, C et BrowsersLa relation entre JavaScript, C et BrowsersMay 01, 2025 am 12:06 AM

INTRODUCTION Je sais que vous pouvez le trouver étrange, que doit faire exactement JavaScript, C et Browser? Ils semblent sans rapport, mais en fait, ils jouent un rôle très important dans le développement Web moderne. Aujourd'hui, nous discuterons du lien étroit entre ces trois. Grâce à cet article, vous apprendrez comment JavaScript fonctionne dans le navigateur, le rôle de C dans le moteur du navigateur et comment ils fonctionnent ensemble pour stimuler le rendu et l'interaction des pages Web. Nous connaissons tous la relation entre JavaScript et Browser. JavaScript est la langue principale du développement frontal. Il fonctionne directement dans le navigateur, rendant les pages Web vives et intéressantes. Vous êtes-vous déjà demandé pourquoi javascr

Node.js diffuse avec dactylographieNode.js diffuse avec dactylographieApr 30, 2025 am 08:22 AM

Node.js excelle dans des E / S efficaces, en grande partie grâce aux flux. Streams traite les données progressivement, en évitant la surcharge de mémoire - idéal pour les fichiers volumineux, les tâches réseau et les applications en temps réel. Combiner les flux avec la sécurité de type dactylographié crée un powe

Python vs JavaScript: considérations de performance et d'efficacitéPython vs JavaScript: considérations de performance et d'efficacitéApr 30, 2025 am 12:08 AM

Les différences de performance et d'efficacité entre Python et JavaScript se reflètent principalement dans: 1) comme un langage interprété, Python fonctionne lentement mais a une efficacité de développement élevée et convient au développement rapide des prototypes; 2) JavaScript est limité au thread unique dans le navigateur, mais les E / S multi-threading et asynchrones peuvent être utilisées pour améliorer les performances dans Node.js, et les deux ont des avantages dans les projets réels.

Les origines de JavaScript: explorer son langage d'implémentationLes origines de JavaScript: explorer son langage d'implémentationApr 29, 2025 am 12:51 AM

JavaScript est originaire de 1995 et a été créé par Brandon Ike, et a réalisé que la langue en langue C. 1.C offre des capacités de programmation élevées et au niveau du système pour JavaScript. 2. La gestion de la mémoire de JavaScript et l'optimisation des performances reposent sur le langage C. 3. La fonctionnalité multiplateforme du langage C aide JavaScript à s'exécuter efficacement sur différents systèmes d'exploitation.

Dans les coulisses: quel langage alimente JavaScript?Dans les coulisses: quel langage alimente JavaScript?Apr 28, 2025 am 12:01 AM

JavaScript s'exécute dans les navigateurs et les environnements Node.js et s'appuie sur le moteur JavaScript pour analyser et exécuter du code. 1) Générer une arborescence de syntaxe abstraite (AST) au stade d'analyse; 2) Convertir AST en bytecode ou code machine à l'étape de compilation; 3) Exécutez le code compilé à l'étape d'exécution.

L'avenir de Python et Javascript: tendances et prédictionsL'avenir de Python et Javascript: tendances et prédictionsApr 27, 2025 am 12:21 AM

Les tendances futures de Python et JavaScript incluent: 1. Python consolidera sa position dans les domaines de l'informatique scientifique et de l'IA, 2. JavaScript favorisera le développement de la technologie Web, 3. Le développement de plate-forme multiplié deviendra un sujet brûlant, et 4. L'optimisation des performances sera le focus. Les deux continueront d'étendre les scénarios d'application dans leurs champs respectifs et de faire plus de percées dans les performances.

Python vs JavaScript: environnements et outils de développementPython vs JavaScript: environnements et outils de développementApr 26, 2025 am 12:09 AM

Les choix de Python et JavaScript dans les environnements de développement sont importants. 1) L'environnement de développement de Python comprend Pycharm, Jupyternotebook et Anaconda, qui conviennent à la science des données et au prototypage rapide. 2) L'environnement de développement de JavaScript comprend Node.js, VScode et WebPack, qui conviennent au développement frontal et back-end. Le choix des bons outils en fonction des besoins du projet peut améliorer l'efficacité du développement et le taux de réussite du projet.

See all articles

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

Video Face Swap

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 !

Outils chauds

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

Version Mac de WebStorm

Version Mac de WebStorm

Outils de développement JavaScript utiles