CoffeeScript - Classi ed ereditarietà
JavaScript non fornisce l'estensione classparola chiave. Possiamo ottenere l'ereditarietà in JavaScript utilizzando oggetti e i loro prototipi. Ogni oggetto ha il proprio prototipo ed eredita funzioni e proprietà dai propri prototipi. Poiché il prototipo è anche un oggetto, ha anche un proprio prototipo.
Sebbene l'ereditarietà prototipale sia molto più potente dell'ereditarietà classica, è difficile e confusa per gli utenti inesperti.
Classi in CoffeeScript
Affrontando questo problema, CoffeeScript fornisce una struttura di base nota come classche è costruito utilizzando i prototipi di JavaScript. È possibile definire una classe in CoffeeScript utilizzando la parola chiave class come mostrato di seguito.
class Class_Name
Esempio
Considera il seguente esempio, qui abbiamo creato una classe denominata Student utilizzando la parola chiave class.
class Student
Se compili il codice sopra, genererà il seguente JavaScript.
var Student;
Student = (function() {
function Student() {}
return Student;
})();
Istanziare una classe
Possiamo istanziare una classe usando l'operatore new proprio come altri linguaggi di programmazione orientati agli oggetti come mostrato di seguito.
new Class_Name
È possibile istanziare la classe (Studente) creata sopra utilizzando il file new operatore come mostrato di seguito.
class Student
new Student
Se compili il codice sopra, genererà il seguente JavaScript.
var Student;
Student = (function() {
function Student() {}
return Student;
})();
new Student;
Definizione di un costruttore
Un costruttore è una funzione che viene invocata quando istanziamo una classe, il suo scopo principale è inizializzare le variabili di istanza. In CoffeeScript, puoi definire un costruttore semplicemente creando una funzione con nomeconstructor come mostrato di seguito.
class Student
constructor: (name)->
@name = name
Qui abbiamo definito un costruttore e assegnato il nome della variabile locale alla variabile di istanza.
Il @ l'operatore è un alias di this parola chiave, viene utilizzata per puntare le variabili di istanza di una classe.
Se posizioniamo @prima di un argomento del costruttore, verrà impostato automaticamente come variabile di istanza. Pertanto, il codice sopra può essere scritto semplicemente come mostrato di seguito -
class Student
constructor: (@name)->
Esempio
Ecco un esempio di un costruttore in CoffeeScript. Salvalo in un file con il nomeconstructor_example.coffee
#Defining a class
class Student
constructor: (@name)->
#instantiating a class by passing a string to constructor
student = new Student("Mohammed");
console.log "the name of the student is :"+student.name
Compiling the code
Apri il prompt dei comandi e compila l'esempio sopra come mostrato di seguito.
c:\>coffee -c constructor_example.coffee
Quando si esegue il comando precedente, verrà prodotto il seguente JavaScript.
// Generated by CoffeeScript 1.10.0
(function() {
var Student, student;
Student = (function() {
function Student(name) {
this.name = name;
}
return Student;
})();
student = new Student("Mohammed");
console.log("The name of the student is :"+student.name);
}).call(this);
Executing the Code
Eseguire l'esempio precedente eseguendo il comando seguente sul prompt dei comandi.
coffee constructor_example.coffee
In esecuzione, l'esempio precedente fornisce il seguente output.
The name of the student is :Mohammed
Proprietà istanza
Come negli oggetti, possiamo anche avere proprietà all'interno di una classe. E questi sono conosciuti comeinstance properties.
Esempio
Considera il seguente esempio. Qui, abbiamo creato variabili (nome, età) e una funzione (messaggio ()) all'interno della classe e vi abbiamo acceduto utilizzando il suo oggetto. Salva questo esempio in un file denominatoinstance_properties_example.coffee
#Defining a class
class Student
name="Ravi"
age=24
message: ->
"Hello "+name+" how are you"
#instantiating a class by passing a string to constructor
student = new Student();
console.log student.message()
Al momento della compilazione, il codice precedente genera il seguente output.
// Generated by CoffeeScript 1.10.0
(function() {
var Student, student;
Student = (function() {
var age, name;
function Student() {}
name = "Ravi";
age = 24;
Student.prototype.message = function() {
return "Hello " + name + " how are you";
};
return Student;
})();
student = new Student();
console.log(student.message());
}).call(this);
Proprietà statiche
Possiamo definire proprietà statiche nella classe. L'ambito delle proprietà statiche è limitato all'interno della classe e creiamo funzioni statiche utilizzando ilthis keyword o il suo alias @symbol e dobbiamo accedere a queste proprietà usando il nome della classe come Class_Name.property .
Esempio
Nell'esempio seguente, abbiamo creato una funzione statica denominata message. e accedervi. Salvalo in un file con il nomestatic_properties_example.coffee.
#Defining a class
class Student
@message:(name) ->
"Hello "+name+" how are you"
console.log Student.message("Raju")
Apri il prompt dei comandi e compila il file CoffeeScript sopra utilizzando il seguente comando.
c:\>coffee -c static_properties_example.coffee
Durante la compilazione, ti dà il seguente JavaScript.
// Generated by CoffeeScript 1.10.0
(function() {
var Student;
Student = (function() {
function Student() {}
Student.message = function(name) {
return "Hello " + name + " how are you";
};
return Student;
})();
console.log(Student.message("Raju"));
}).call(this);
Esegui il coffeeScript sopra nel prompt dei comandi come mostrato di seguito.
c:\>coffee static_properties_example.coffee
Durante l'esecuzione, l'esempio precedente fornisce il seguente output.
Hello Raju how are you
Eredità
In CoffeeScript, possiamo ereditare le proprietà di una classe in un'altra classe usando extends parola chiave.
Esempio
Di seguito è riportato un esempio di ereditarietà in CoffeeScript. Qui abbiamo due classi, vale a direAdd e My_class. Abbiamo ereditato le proprietà della classe denominata Add nella classe My_class e vi abbiamo acceduto utilizzando ilextends parola chiave.
#Defining a class
class Add
a=20;b=30
addition:->
console.log "Sum of the two numbers is :"+(a+b)
class My_class extends Add
my_class = new My_class()
my_class.addition()
CoffeeScript utilizza l'eredità prototipale dietro le quinte. In CoffeeScript, ogni volta che creiamo istanze, il costruttore della classe genitore viene invocato fino a quando non lo sovrascriviamo.
Possiamo invocare il costruttore della classe genitore dalla sottoclasse, usando il super() parola chiave come mostrato nell'esempio riportato di seguito.
#Defining a class
class Add
constructor:(@a,@b) ->
addition:=>
console.log "Sum of the two numbers is :"+(@a+@b)
class Mul extends Add
constructor:(@a,@b) ->
super(@a,@b)
multiplication:->
console.log "Product of the two numbers is :"+(@a*@b)
mul = new Mul(10,20)
mul.addition()
mul.multiplication()
Classi dinamiche
CoffeeScript utilizza l'ereditarietà prototipale per ereditare automaticamente tutte le proprietà di istanza di una classe. Ciò garantisce che le classi siano dinamiche; anche se aggiungi proprietà a una classe genitore dopo che un figlio è stato creato, la proprietà verrà comunque propagata a tutti i suoi figli ereditati.
class Animal
constructor: (@name) ->
class Parrot extends Animal
Animal::rip = true
parrot = new Parrot("Macaw")
console.log "This parrot is no more" if parrot.rip
All'esecuzione, il CoffeeScript di cui sopra genera il seguente codice JavaScript.
// Generated by CoffeeScript 1.10.0
(function() {
var Animal, Parrot, parrot,
extend = function(child, parent) { for (var key in parent) {
if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() {
this.constructor = child; } ctor.prototype = parent.prototype;
child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
Animal = (function() {
function Animal(name) {
this.name = name;
}
return Animal;
})();
Parrot = (function(superClass) {
extend(Parrot, superClass);
function Parrot() {
return Parrot.__super__.constructor.apply(this, arguments);
}
return Parrot;
})(Animal);
Animal.prototype.rip = true;
parrot = new Parrot("Macaw");
if (parrot.rip) {
console.log("This parrot is no more");
}
}).call(this);