ホームページ ウェブフロントエンド jsチュートリアル json_jsonを使用したフロントエンドとバックエンド間の相互値転送の詳細説明

json_jsonを使用したフロントエンドとバックエンド間の相互値転送の詳細説明

May 16, 2016 pm 04:22 PM
json

フロントエンドとバックエンドの間で相互に値を転送するための値が多すぎると、書き込みが面倒で疲れ、エラーが発生しやすくなります。以下に、マーク タグ属性を使用して値を渡す一連の方法を示します。バックエンド値の取得とフロントエンド バインディングが大幅に簡素化されました。

1. json オブジェクトを文字列に変換します

コードをコピー コードは次のとおりです:

$.extend({
//jsonオブジェクトを文字列に変換 [jqueryにはこのメソッドがないようです]
toJSONString: 関数 (オブジェクト) {
if (object == null)
return;
var type = オブジェクトのタイプ;
If ('オ​​ブジェクト' == 型) {
If (Array == object.constructor) type = 'array';
else if (RegExp == object.constructor) type = 'regexp';
else type = 'object';
}
スイッチ (タイプ) {
ケース「未定義」:
ケース「不明」:
return;
休憩;
ケース '関数':
ケース 'ブール値':
ケース '正規表現':
return object.toString();
休憩;
ケース '番号':
isFinite(object) を返しますか? object.toString() : 'null';
休憩;
ケース '文字列':
return '"' object.replace(/(\|")/g, "\$1").replace(/n|r|t/g, function () {
var a = argument[0];
return (a == 'n') ? '\n' : (a == 'r') ? '\r' : (a == 't') ? '"'; 休憩;
ケース 'オブジェクト':
If (object === null) return 'null';
var results = [];
for (オブジェクトの var プロパティ) {
var value = $.toJSONString(object[property]);
                         if (値 !== 未定義) results.push($.toJSONString(property) ':' value);
                     }
                     return '{' results.join(',') '}';
                     休憩;
                 ケース '配列':
                     var results = [];
                     for (var i = 0; i                          var value = $.toJSONString(object[i]);
                         if (値 !== 未定義) results.push(値);
                     }
                     return '[' results.join(',') ']';
                     休憩;
             }
         }
     });

二、创建データ容器对象 [用来绑要传给後台的前台控件值]

复制代码代码如下:

var DataClass = {
作成: function () {
戻り関数 () {
This.myinit.apply (this, argument); // 作成オブジェクトのコンストラクター // 引数のパラメーター収集システム名を間違って記述することはできません
}
}
}
var MyDataPack = DataClass.create();
MyDataPack.prototype = {
//初期化
MyInit: 関数 (URL、操作、パラメータ) {
This.data = new Object() //全データ容量
var bdata = new Object();
bdata.url = URL; bdata.operation = オペレーション;//オペレーション
bdata.params = params; This.data.BasicData = bdata; //基本データ
},
//次のようなデータを追加します: addValue("obj", "111");
addValue: function (p, obj) {
This.data[p] = obj;
}、
//すべてのマークコントロールの値を取得し、データを書き込みます
GetValueSetData: 関数 (togName) {
varvalues = Object() // 値のコレクション
$("[subtag='" togName "']").each(function () {
//入力型コントロールの場合
If (this.localName == "input") {
//テキストコントロールの場合
If (this.type == "text" || this.type == "hidden") {
値[this.id] = this.value;
} else if (this.type == "...") {
}                                                                                                                     }
else if (this.localName == "...") {
}
                                                                            });
This.data[togName] =values;//データコレクションに追加
},
//次のような値: getValue("BasicData")
GetValue: 関数 (p) {
return this.data[p];
},
// URL を取得または設定します
GetUrl: 関数 (URL) {
If (URL)
This.data.BasicData["url"] = url;
その他
return this.data.BasicData["url"];
}

//値を文字列オブジェクトに変換します data
GetJsonData: function () {
return $.toJSONString(this.data);
}
}

3. バインドされたフロントエンド データ オブジェクトを作成します (バックグラウンドから渡された値を読み取り、それをフロントエンド ページにバインドするために使用されます)

コードをコピーします コードは次のとおりです:

var MyDataBinder = {
//データを制御データにバインドします: data タグ: タグ
バインド: 関数 (データ、タグ) {
var MJson = $.parseJSON(data);
//マークされたタグのみをバインドします
$("[bindtag='" タグ "']").each(function () {
If (this.localName == "input") {
if (MJson[this.id]) //値がバックグラウンドで渡された場合
$(this).attr("値", MJson[this.id]);
}
else if (this.localName == "...") {
}
//....
});
}
};

4. 使用例

フロントエンド HTML:

コードをコピーします コードは次のとおりです:

<表>

                                                                                                                                                                                                                                                                                                       





                                                                                                                                                                                                                                                                                                     



フロントエンド js:

コードをコピー コードは次のとおりです:

//====================使用例========================= ============
var MyDataPack = new MyDataPack("Handler1.ashx", "CESHI", "");
MyDataPack.getValueSetData("subtag");//オブジェクトにコントロールデータを書き込む "subtag"はコントロール値を取得するためのタグです
//-----------------フロントエンドの値をバックエンドに転送--------------
$.post(MyDataPack.getUrl(), MyDataPack.getJsonData(), 関数 (データ) {
//-------------------背景の値を前景にバインドします-----------------
MyDataBinder.Bind(data, "bind"); //「bind」はバインドされるコントロールのラベル
です });

舞台裏:

コードをコピーします コードは次のとおりです:

public void ProcessRequest(HttpContext context)
{
Context.Response.ContentType = "テキスト/プレーン";
//====================前景値を取得======================== == ====================
//バックグラウンドで渡されるのはjsonオブジェクトの変換された文字列なので、すべてのデータはパラメータとして渡されます
var 値 = context.Request.Form[0];
//アセンブリ System.Web.Extensions.dll を導入する必要があります
JavaScriptSerializer _jsSerializer = 新しい JavaScriptSerializer();
// json オブジェクト文字列を Dictionary オブジェクトに変換します
辞書<文字列, 辞書<文字列, 文字列>> dic = _jsSerializer.Deserialize<辞書<文字列, 辞書<文字列, 文字列>>>(値);
// これで、dic にはフロントデスクから渡されたすべての値が含まれるようになり、それらを自由に使用できます。
String inp_2 = dic["subtag"]["inp_2"];//これにより、フロントページのinp_2のidを持つ制御値の値が直接取得されます
//====================== フロントデスクに値を渡します=================== ===== =====================
辞書<文字列, 文字列> dic2 = 新しい辞書<文字列, 文字列>();
dic2.Add("inp_1", "Modify 1");//ここでは、対応するコントロール ID を使用して値を渡します
dic2.Add("inp_2", "変更 2");
dic2.Add("inp_3", "変更 3");
Context.Response.Write(_jsSerializer.Serialize(dic2));
}

フロントエンドとバックエンドの値の転送を実現するために json を使用することについて明確に理解していますか? ご質問がある場合は、メッセージを残してください

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

golang WebSocketとJSONの組み合わせ:データ送信と解析を実現 golang WebSocketとJSONの組み合わせ:データ送信と解析を実現 Dec 17, 2023 pm 03:06 PM

golangWebSocket と JSON の組み合わせ: データ送信と解析の実現 現代の Web 開発では、リアルタイムのデータ送信がますます重要になっています。 WebSocket は双方向通信を実現するために使用されるプロトコルで、従来の HTTP リクエスト/レスポンス モデルとは異なり、WebSocket を使用すると、サーバーがクライアントにデータをアクティブにプッシュできます。 JSON (JavaScriptObjectNotation) は、簡潔で読みやすいデータ交換用の軽量形式です。

Javaで@Exposeアノテーションを使用してJSONからフィールドを除外するにはどうすればよいですか? Javaで@Exposeアノテーションを使用してJSONからフィールドを除外するにはどうすればよいですか? Sep 16, 2023 pm 09:49 PM

Gson@Expose アノテーションを使用して、フィールドがシリアル化または逆シリアル化のために公開されているかどうか (含まれているかどうか) をマークできます。 @Expose アノテーションは 2 つのパラメータを取ることができ、各パラメータはブール値で、値 true または false を取ることができます。 GSON が @Expose アノテーションに反応できるようにするには、GsonBuilder クラスを使用して Gson インスタンスを作成し、excludeFieldsWithoutExposeAnnotation() メソッドを呼び出す必要があります。これにより、Expose アノテーションのないすべてのフィールドがシリアル化または逆シリアル化から除外されるように Gson が設定されます。構文 publicGsonBuilderexclud

MySQL5.7とMySQL8.0の違いは何ですか? MySQL5.7とMySQL8.0の違いは何ですか? Feb 19, 2024 am 11:21 AM

MySQL5.7 と MySQL8.0 は 2 つの異なる MySQL データベース バージョンであり、それらの間には主な違いがいくつかあります: パフォーマンスの向上: MySQL8.0 では、MySQL5.7 と比較してパフォーマンスがいくつか向上しています。これには、より優れたクエリ オプティマイザー、より効率的なクエリ実行プランの生成、より優れたインデックス作成アルゴリズムと並列クエリなどが含まれます。これらの改善により、クエリのパフォーマンスとシステム全体のパフォーマンスが向上します。 JSON サポート: MySQL 8.0 では、JSON データのストレージ、クエリ、インデックス作成など、JSON データ型のネイティブ サポートが導入されています。これにより、MySQL での JSON データの処理と操作がより便利かつ効率的になります。トランザクション機能: MySQL8.0 では、アトミックなどのいくつかの新しいトランザクション機能が導入されています。

PHP 配列を JSON に変換するためのパフォーマンス最適化のヒント PHP 配列を JSON に変換するためのパフォーマンス最適化のヒント May 04, 2024 pm 06:15 PM

PHP 配列を JSON に変換するためのパフォーマンスの最適化方法には、JSON 拡張機能と json_encode() 関数の使用、文字エスケープを回避するためのバッファーの使用、およびサードパーティのエンコード結果の使用の検討が含まれます。 JSONエンコーディングライブラリ。

Jackson ライブラリのアノテーションは、JSON のシリアル化と逆シリアル化をどのように制御しますか? Jackson ライブラリのアノテーションは、JSON のシリアル化と逆シリアル化をどのように制御しますか? May 06, 2024 pm 10:09 PM

Jackson ライブラリのアノテーションは、JSON のシリアル化と逆シリアル化を制御します。 シリアル化: @JsonIgnore: プロパティを無視します @JsonProperty: 名前を指定します @JsonGetter: get メソッドを使用します @JsonSetter: set メソッドを使用します Deserialization: @JsonIgnoreProperties: プロパティ @ JsonProperty を無視します:名前を指定 @JsonCreator: コンストラクターを使用 @JsonDeserialize: カスタム ロジック

Pandas の使用法チュートリアル: JSON ファイルを読み取るためのクイック スタート Pandas の使用法チュートリアル: JSON ファイルを読み取るためのクイック スタート Jan 13, 2024 am 10:15 AM

クイック スタート: JSON ファイルを読み取る Pandas の方法、特定のコード サンプルが必要です はじめに: データ分析とデータ サイエンスの分野では、Pandas は重要な Python ライブラリの 1 つです。豊富な機能と柔軟なデータ構造を備え、さまざまなデータを簡単に処理・分析できます。実際のアプリケーションでは、JSON ファイルを読み取る必要がある状況によく遭遇します。この記事では、Pandas を使用して JSON ファイルを読み取る方法を紹介し、具体的なコード例を添付します。 1.パンダのインストール

C# 開発で XML および JSON データ形式を処理する方法 C# 開発で XML および JSON データ形式を処理する方法 Oct 09, 2023 pm 06:15 PM

C# 開発で XML および JSON データ形式を処理する方法には、特定のコード サンプルが必要です。現代のソフトウェア開発では、XML と JSON の 2 つのデータ形式が広く使用されています。 XML (Extensible Markup Language) はデータの保存と送信に使用されるマークアップ言語であり、JSON (JavaScript Object Notation) は軽量のデータ交換形式です。 C# 開発では、XML と JSON データの処理と操作が必要になることがよくありますが、この記事では、C# を使用してこれら 2 つのデータ形式を処理し、添付する方法に焦点を当てます。

golang の json.MarshalIndent 関数を使用して、構造をフォーマットされた JSON 文字列に変換します。 golang の json.MarshalIndent 関数を使用して、構造をフォーマットされた JSON 文字列に変換します。 Nov 18, 2023 pm 01:59 PM

golang で json.MarshalIndent 関数を使用して、構造をフォーマットされた JSON 文字列に変換します。Golang でプログラムを作成するとき、多くの場合、構造を JSON 文字列に変換する必要があります。このプロセスでは、 json.MarshalIndent 関数が役に立ちます。フォーマットされた出力。以下では、この関数の使用方法と具体的なコード例を詳しく説明します。まず、データを含む構造体を作成しましょう。以下は目安です

See all articles