TypeScriptのイントロがDev.office.comにあるので眺めてみた。
tsとして以下の例が載っている。
class Student {
fullName: string;
constructor( public firstName, public middleInitial, public lastName){
this.fullName = firstName + " "+ middleInitial + " " + lastName;
}
}
interface Person {
firstName: string;
lastName : string;
}
function greeter(person: Person){
return "Hello, "+ person.firstName + " " + person.lastName;
}
let user =new Student("Jane","G.","Doe");
document.body.innerHTML=greeter(user);
これをJSにコンパイルするとこうなる(WebStormはプラグインが動いてダイナミックに自動生成する)
var Student = (function () {
function Student(firstName, middleInitial, lastName) {
this.firstName = firstName;
this.middleInitial = middleInitial;
this.lastName = lastName;
this.fullName = firstName + " " + middleInitial + " " + lastName;
}
return Student;
}());
function greeter(person) {
return "Hello, " + person.firstName + " " + person.lastName;
}
var user = new Student("Jane", "G.", "Doe");
document.body.innerHTML = greeter(user);
うむむむむ。JSのほうがパターンに親近感があって読みやすいんですけど。でもそういうことじゃなくてTypeやクラスの定義がしっかりできて、あとあとの管理が楽、ということなんだろうな。