Maison > interface Web > js tutoriel > Cours dans CoffeeScript

Cours dans CoffeeScript

William Shakespeare
Libérer: 2025-02-24 10:31:14
original
635 Les gens l'ont consulté

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
Copier après la connexion
Copier après la connexion

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
Copier après la connexion
Copier après la connexion

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
Copier après la connexion
é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
Copier après la connexion
Copier après la connexion

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
Copier après la connexion
Copier après la connexion

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 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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal