クラスメンバーをイベントハンドラーとして使用するためのJavaScriptのベストプラクティスまたは一般的な方法はありますか?
次の簡単な例を考えてみましょう。
<head>
<script language="javascript" type="text/javascript">
ClickCounter = function(buttonId) {
this._clickCount = 0;
document.getElementById(buttonId).onclick = this.buttonClicked;
}
ClickCounter.prototype = {
buttonClicked: function() {
this._clickCount++;
alert('the button was clicked ' + this._clickCount + ' times');
}
}
</script>
</head>
<body>
<input type="button" id="btn1" value="Click me" />
<script language="javascript" type="text/javascript">
var btn1counter = new ClickCounter('btn1');
</script>
</body>
イベントハンドラのbuttonClickedが呼び出されますが、_clickCountメンバーにアクセスできないか、他のオブジェクトを指しています。
この種の問題に関する良いヒント/記事/リソースはありますか?