0

http://jsfiddle.net/Lijo/zPAfF/6/に示すようなHTMLページがあります 。「searchReportButton」ボタンをクリックすると、javascript関数「checkSession」が呼び出されます。「checkSession」関数内には、以下jquery.ajaxのリストへの呼び出しがありweb methodます。Webメソッドは正常に機能しており、JavaScriptの成功コールバックで結果を「ACTIVE」としてアラートすることができます。

コンテキストをこのように設定しました。

 context: this,  //CONTEXT 

次のコードが「読み込み中…」というテキストを警告することを期待しています。が設定されているので、thisで動作すると仮定します。しかし、それはテキストを示していません。success callbackcontext

if (result == "ACTIVE") 
{       
    var selectedTable = $(this).closest('.dateFilter').siblings('.sentDatesSection').find('.reportSentDatesDiv');

    alert($(selectedTable).text());

}

質問

コールバックでコンテキストを取得するには、何を修正する必要がありますか?

Webメソッド

    [WebMethod(CacheDuration = 0)]
    public static string CheckSessionExpiry(string empID)
    {

        return "ACTIVE";
    }

ここに画像の説明を入力してください

jQuery

$(document).ready(function() {
    var searchReportButton = $('.searchReportButton');
    searchReportButton.click(function() {
        var selectedTable = $(this).closest('.dateFilter').siblings('.sentDatesSection').find('.reportSentDatesDiv');
        alert($(selectedTable).text());
        checkSession();
        return false;
    });
});

function checkSession() {
    var empID = 101;
    alert('Function Reached');
    $.ajax({
        type: "POST",
        url: "Error.aspx/CheckSessionExpiry",
        data: '{"empID": "' + empID + '"}',
        contentType: "application/json; charset=utf-8",
        dataType: "json",
        context: this,
        //CONTEXT
        success: handleSessionResult
    });
}

function handleSessionResult(result) {
    if (result.hasOwnProperty("d")) {
        result = result.d
    }
    if (result == "ACTIVE") {
        var selectedTable = $(this).closest('.dateFilter').siblings('.sentDatesSection').find('.reportSentDatesDiv');
        alert($(selectedTable).text());
    }
}​

HTML

<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1">
<title>Report List </title>

</head>
<body>
<form>

<div id="wrapper">
    <div id="container">
        <div id="centralContainer">
            <div id="mainContainer">
                <div id="contentHolderDiv" class="contentHolderDiv">
                    <div id="searchContainer" class="searchContainer">
                        <div id="entryValues" class="repeaterContainer">
                            <div class="repeaterTableBorder">
                                <div class="repeaterRecord">
                                    <div class="repeaterIdentifier">
                                        <div class="reportTitle">
                                            Daily Financial Transaction:
                                        </div>
                                    </div>

                                    <div class="viewLogTitle">
                                        <div class="viewLogText">
                                            View Report Log
                                        </div>
                                    </div>
                                    <div id="reportLog" class="reportLog">
                                        <div class="dateFilter">
                                            <div class="filterElements">
                                                <div class="filterContents">
                                                    <input type="submit" name="ctl00$detailContentPlaceholder$repReports$ctl00$btnSubmit"
                                                        value="Get Reports" id="detailContentPlaceholder_repReports_btnSubmit_0" class="searchReportButton" />
                                                </div>
                                            </div>
                                        </div>
                                        <div class="sentDatesSection">
                                            <div class="reportSentDatesDiv">
                                                <p>
                                                    Loading...</p>
                                            </div>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>
                    <div class="clear">
                    </div>
                </div>
            </div>
            <div class="clear">
            </div>
        </div>
    </div>
</div>
</form>
<script type="text/javascript" src="http://ajax.aspnetcdn.com/ajax/jquery/jquery-1.4.1.js"></script>

4

2 に答える 2

1

関数thisに引数として渡します。checkSession

checkSession(this);

その後:

function checkSession(context) {
    var empID = 101;
    alert('Function Reached');
    $.ajax({
        type: "POST",
        url: "Error.aspx/CheckSessionExpiry",
        data: JSON.stringify({ empID: empID }),
        contentType: "application/json; charset=utf-8",
        dataType: "json",
        context: context,  //CONTEXT
        success: handleSessionResult

        }
    });
}

また、リクエストが適切に JSON 形式であることを確認するために、メソッド$.ajaxを使用するように呼び出しを修正したことにも注目してください。繰り返しますが、文字列連結 (演算子) を使用して JSON を構築することは決してありません。このメソッドは、最新のすべてのブラウザーにネイティブに組み込まれています。また、 IE6 などの中生代のブラウザをサポートする必要がある場合は、 json2.jsスクリプトをページに参​​照できます。JSON.stringify+JSON.stringify

于 2012-12-02T15:14:22.353 に答える
1

または、 を使用することもできますcall

checkSession.call(this);

または、その兄弟apply

于 2012-12-02T15:21:20.933 に答える