ホームページ >ウェブフロントエンド >jsチュートリアル >Ajaxバックグラウンド成功から送信されるJSONデータの問題の簡単な分析

Ajaxバックグラウンド成功から送信されるJSONデータの問題の簡単な分析

韦小宝
韦小宝オリジナル
2018-05-14 15:04:401966ブラウズ

最近、JQueryのajaxメソッドを使用する場合、返却する必要があるデータはjsonデータですが、成功返却では返却方法に応じてデータ処理が異なる方法でjsonデータを生成します。以下のエディタでは $.ajax メソッドでの扱い方を紹介していますので、ajax に興味のある方はぜひご覧ください。

最近、JQueryのajaxメソッドを使用する場合、返却する必要があるデータはjsonデータであり、成功返却では返却メソッドに応じてデータ処理が異なる方法でjsonデータを生成します。 $.ajaxメソッドでの扱い方を簡単に説明します。

まず、転送する JSON データを指定します: [{"demoData":"This Is The JSON Data"}]

1、通常の aspx ページを使用して処理します

$.ajax({ 
type: "post", 
url: "Default.aspx", 
dataType: "json", 
success: function (data) { 
$("input#showTime").val(data[0].demoData); 
}, 
error: function (XMLHttpRequest, textStatus, errorThrown) { 
alert(errorThrown); 
} 
});

バックグラウンドでデータを送信するためのコードは次のとおりです

Response.Clear(); 
Response.Write("[{\"demoData\":\"This Is The JSON Data\"}]"); 
Response.Flush(); 
Response.End();

この処理メソッドは、渡されたデータを json データに直接解析します。つまり、ここでのフロントエンド js コードは、data[0].demoData などの文字列データではなく、データを json オブジェクト データに直接解析する可能性があります。この json オブジェクト データを直接使用します

2、Web サービス (asmx) を使用して処理します

この処理メソッドは、次のコードに示すように、渡されたデータを json オブジェクト データとしてではなく、文字列として扱います

$.ajax({ 
type: "post", 
url: "JqueryCSMethodForm.asmx/GetDemoData", 
dataType: "json",/*这句可用可不用,没有影响*/ 
contentType: "application/json; charset=utf-8", 
success: function (data) { 
$("input#showTime").val(eval('(' + data.d + ')')[0].demoData); 
//这里有两种对数据的转换方式,两处理方式的效果一样 
//$("input#showTime").val(eval(data.d)[0].demoData); 
}, 
error: function (XMLHttpRequest, textStatus, errorThrown) { 
alert(errorThrown); 
} 
});

以下はasmx メソッド コード

public static string GetDemoData() { 
return "[{\"demoData\":\"This Is The JSON Data\"}]"; 
}

ここでのこの処理メソッドは、渡された json データを文字列として扱うため、このデータは実際の json オブジェクト データになるように eval 処理する必要があります。

それは

success:function(data){ 
eval(data); 
}
です

以上、編集者が紹介したAjaxバックグラウンドサクセスから送信されるJSONデータの問題でしたので、皆様のお役に立てれば幸いです! !

関連する推奨事項:

jQuery.ajax の成功と完了の違い

ajax は成功を受け取らず、エラーのみを受け取り、リクエストステータスコードは 200 です。

javascript - 成功の場合Ajaxのコールバック関数 JSONデータを出力する方法

以上がAjaxバックグラウンド成功から送信されるJSONデータの問題の簡単な分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。