でましたね。 Prototype 1.6.0 release candidate
WEB界隈から離れてしばらくたちますが、またいつWEB界隈に戻るかわからないので一応追ってます。
1.6ではついにClass周りに手が入りました。Prototype.jsといえばシンプルすぎるClass周りとプロパティをコピーするというなんちゃって継承がウリ(?)だったわけですが、1.6からは違います。もう オレオレクラス定義ライブラリ をわざわざ使わなくても大丈夫。
公式にも例がありますが、こんな感じでちゃんと継承できるようになりました。
var Animal = Class.create({
initialize: function(name) {
this.name = name;
},
eat: function() {
return this.say("Yum!");
},
say: function(message) {
return this.name + ": " + message;
}
});
var Eatable = {
eaten : function() {
return this.say("help me!!!");
}
}
var Mouse = Class.create(Animal, {
});
//syntax sugar for Object.extend
Class.mixin(Mouse.prototype, Eatable);
// subclass that augments a method
var Cat = Class.create(Animal, {
eat: function($super, food) {
if (food instanceof Mouse) return [food.eaten(),$super()].join("\n");
else return this.say("Yuk! I only eat mice.");
}
});
var a = new Cat("Tama");
alert(a.eat(new Mouse("Nezumy mouse")));
単にプロトタイプチェーンをつなげるだけではなくて、オーバライドされたメソッドの引数名を取得して(toStringしてgrepですね)、$superだった場合、自動的に親クラスのメソッドを$superとして渡してくれます。地味に便利。
あとはsyntax sugarとしてClass.mixinがあります。まぁObject.extendなんですが、こっちの方がわかりやすいですよね。
そのほかもいっぱい機能が追加れさてれてますね。個人的には document.observe("contentloaded", function() { ... })
て感じでサポートされたDOM完了時点でのイベントと、
$("container").observe("titleChanged", function(event) {
this.highlight({ duration: 0.5 });
});
$("title").fire("titleChanged");
って感じのカスタムイベントが必ず使いそうな機能かな。
資格の勉強とかもそろそろしなきゃなー、と思いつつ、Scalaでパーサコンビネータライブラリがついたので、Schemeの処理系でも実装したいなあ、と思い始めてる今日この頃。