Maison >interface Web >js tutoriel >Cours dans CoffeeScript
Points de base
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:
<code class="language-coffeescript">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</code>
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.
<code class="language-coffeescript">functionName: (arguments) -> code</code>
Classe d'héritage
Maintenant, nous voulons un cours qui hérite de la bourgeoisie. Nous le nommons sénateur.
Cette classe
<code class="language-coffeescript">class Senator extends Bourgeoisie worry: -> console.log("民调下跌了 1%!") senator = new Senator(45, 992) senator.worry() # "民调下跌了 1%!" senator.profit(6, 10) # 132264</code>é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. 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. <code class="language-coffeescript">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</code>
<code class="language-coffeescript">functionName: (arguments) ->
code</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?
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!