0

asp.net ajax での値の割り当てと取得に問題があります。タイムスタンプの値は未定義です

コード:

 /// <reference name="MicrosoftAjax.js"/>

 Type.registerNamespace("LabelTimeExtender1");

 LabelTimeExtender1.ClientBehavior1 = function(element) {
 LabelTimeExtender1.ClientBehavior1.initializeBase(this, [element]);
 this._testelement=this.get_element();
 this._timestamp= this.get_element().attributes['TimeStamp'].value;
 alert(_timestamp);

},

 LabelTimeExtender1.ClientBehavior1.prototype = {
initialize: function() {
    LabelTimeExtender1.ClientBehavior1.callBaseMethod(this, 'initialize');
    setInterval (this.timer,1000);
    alert("after");

},
dispose: function() {        
    //Add custom dispose actions here
    LabelTimeExtender1.ClientBehavior1.callBaseMethod(this, 'dispose');
},
timer: function(){

   alert(this.timestamp);
            var splitdate=this._timestamp.split(/[:]+/);
            alert(splitdate);
            var date= new Date(this._timestamp);
            alert( date.toString());
            var datenow= new Date ();
            alert(datenow.toString());
            this._element.innerText=" ";
            alert(this._element);
              if(date.getUTCFullYear<datenow.getUTCFullYear)
            {
            alert("year");
             var myelement= this.get_element();
             myelement .innerHTML= date.getUTCFullYear.toString();
            }
            if(date.getUTCMonth<datenow.getUTCMonth)
            {
            alert("month");
            this.get_element().innerHTML=date.getUTCMonth.toString();
            }
            if(date.getUTCDay<datenow.getUTCDay)
            {
            this.get_element().innerHTML=date.getUTCDay.toString();
            }
            if(date.getUTCHours <datenow.getUTCHours )
            {
             this.get_element().innerHTML=date.getUTCHours .toString();
            }
            if(date.getUTCMinutes<datenow.getUTCMinutes)
            {
            this.get_element().innerHTML=date.getUTCMinutes.toString();
            }


},
   set_timestamp: function(value)
  {
  this._timestamp=value;
  },

    get_timestamp: function()
   {
   return this._timestamp;
   }



}
 LabelTimeExtender1.ClientBehavior1.registerClass('LabelTimeExtender1.ClientBehavior1',  Sys.UI.Behavior);

if (typeof(Sys) !== 'undefined') Sys.Application.notifyScriptLoaded();

値が_timestamp定義されていないのはなぜですか?

4

1 に答える 1

0

関数に設定するコードを移動することをお勧めthis._timestampしますinitialize

私の他の提案は、カプセル化を確実にするために、独自のコード内でもゲッターとセッターを使用することです。したがって、アラートは実際にはalert(this.get_timestamp()). そして、あなたのinitialize関数では、 を呼び出しますthis.set_timestamp(this.get_element().attributes['TimeStamp'].value)

コメントのおかげで、問題は実際には setInterval 呼び出しにあることがわかりました。を呼び出すwindow.setInterval(this.timer, 1000);とき、timer関数が呼び出されるときは、オブジェクトではなく をthis参照しwindowます。代わりに、次のようにします。

var self = this;
window.setInterval(function () { 
    self.timer(); 
}, 1000);

これにより、this内部がtimer()正しいオブジェクトを参照するようになります。

于 2012-08-31T14:21:42.177 に答える