0

私は ASP.NET Ajax に詳しくありません。メソッドCreateがhtml要素をajaxコンポーネントにアタッチしていることは知っていました。しかし、現在のコンポーネントから切り離す方法がわかりません。そしてもう1枚貼ります。

コンポーネント タイプ に要素ctl00_PlaceHolderMain_UserRegistration_txbPassword1が関連付けられてAccelaWebControlExtender.HelperBehaviorおり、作成されたコンポーネント ID が であるとしctl00_PlaceHolderMain_UserRegistration_txbPassword1_helper_bhvます。コードは以下のようになります。見直してください。

Sys.Application.add_init(function() {
    $create(AccelaWebControlExtender.HelperBehavior, {"closeTitle":"Close","id":"ctl00_PlaceHolderMain_UserRegistration_txbPassword1_helper_bhv","isRTL":false,"title":"Help"}, null, null, $get("ctl00_PlaceHolderMain_UserRegistration_txbPassword1"));
});

最初にIDでコンポーネントを取得してから、デタッチとアタッチ作業を行う必要があると思います。誰かが私に助けてくれることを願っています。ありがとう。

4

1 に答える 1

1

いくつかの調査を行った後Extend Web server control that encapsulates a client behavior、Asp.net Ajax で呼び出され、コンポーネントの添付が Asp.net によって自動的に行われることがわかりました。Sys.Application.add_init(function()コードが Asp.net によって自動的に aspx ページに生成されていることがわかります。したがって、Web Server Control の元の動作をカスタマイズしたい場合は、Javascript OOP の方法 (昔と同じ) で作成できると思います。

例:元の動作コードがブローの場合。

// Register the namespace for the control.
Type.registerNamespace('Samples');

//
// Define the behavior properties.
//
Samples.FocusBehavior = function(element) { 
    Samples.FocusBehavior.initializeBase(this, [element]);

    this._highlightCssClass = null;
    this._nohighlightCssClass = null;
}

//
// Create the prototype for the behavior.
//
Samples.FocusBehavior.prototype = {
    initialize : function() {
        Samples.FocusBehavior.callBaseMethod(this, 'initialize');

        $addHandlers(this.get_element(), 
                     { 'focus' : this._onFocus,
                       'blur' : this._onBlur },
                     this);

        this.get_element().className = this._nohighlightCssClass;
    },

    dispose : function() {
        $clearHandlers(this.get_element());

        Samples.FocusBehavior.callBaseMethod(this, 'dispose');
    },

    //
    // Event delegates
    //
    _onFocus : function(e) {
        if (this.get_element() && !this.get_element().disabled) {
            this.get_element().className = this._highlightCssClass;          
        }
    },

    _onBlur : function(e) {
        if (this.get_element() && !this.get_element().disabled) {
            this.get_element().className = this._nohighlightCssClass;          
        }
    },


    //
    // Behavior properties
    //
    get_highlightCssClass : function() {
        return this._highlightCssClass;
    },

    set_highlightCssClass : function(value) {
        if (this._highlightCssClass !== value) {
            this._highlightCssClass = value;
            this.raisePropertyChanged('highlightCssClass');
        }
    },

    get_nohighlightCssClass : function() {
        return this._nohighlightCssClass;
    },

    set_nohighlightCssClass : function(value) {
        if (this._nohighlightCssClass !== value) {
            this._nohighlightCssClass = value;
            this.raisePropertyChanged('nohighlightCssClass');
        }
    }
}

// Optional descriptor for JSON serialization.
Samples.FocusBehavior.descriptor = {
    properties: [   {name: 'highlightCssClass', type: String},
                    {name: 'nohighlightCssClass', type: String} ]
}

// Register the class as a type that inherits from Sys.UI.Control.
Samples.FocusBehavior.registerClass('Samples.FocusBehavior', Sys.UI.Behavior);

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

Samples.FocusBehaviorJavascript オブジェクトのメソッドのいくつかをオーバーライドして、カスタマイズを実現できると思います。

例えば ​​。

Samples.FocusBehavior.prototype._onFocusこのようにスクリプトでオーバーライドできます。

Samples.FocusBehavior.prototype._onFocus = function (e) {
    alert('test');
    if (this.get_element() && !this.get_element().disabled) {
        this.get_element().className = this._highlightCssClass;
    }
};

このコードがブラウザによって元のコードの後に​​解析されることを確認してください。
これが正しい方法かどうかはわかりません。誰かがそれを確認するのを手伝ってくれることを願っています.どうもありがとう.

これがそのチュートリアルです。見直してください。乾杯。

于 2013-06-13T16:24:37.813 に答える