今日のインターネットでは、AJAX はもはや聞きなれない言葉ではありません。 AJAX といえば、RSS をきっかけに登場した XML がすぐに思い浮かぶかもしれません。特に PHP5 や、最も軽量な SimpleXML などの多数の XML パーサーの登場により、XML 解析はおそらく問題ではなくなりました。ただし、AJAX の場合、XML 解析はフロントエンド Javascript のサポートに重点を置いています。 XML を解析したことがある人なら誰でも、ツリーとノードに混乱すると思います。 XML が非常に優れたデータ保存方法であることは否定できませんが、その柔軟性により解析が困難になります。もちろん、ここで言及する難しさは、この記事の主役である JSON に関連しています。
JSONとは何ですか?このコンセプトについては繰り返しません。平たく言えば、PHP のシリアル化された文字列のようなデータ ストレージ形式です。データの説明です。たとえば、配列をシリアル化して保存すると、簡単に逆シリアル化して適用できます。 JSON にも同じことが当てはまりますが、クライアント側の Javascript とサーバー側の PHP の間に対話型のブリッジが構築される点が異なります。 PHP を使用して JSON 文字列を生成し、この文字列をフロントエンド Javascript に渡します。Javascirpt はそれを簡単に JSON に変換して適用できます。簡単に言うと、本当に配列のように見えます。
身近なところでは、JSON の使用方法について説明します。 PHP5.2 には JSON のサポートが組み込まれています。もちろん、このバージョンより前のバージョンの場合は、市場に多数の PHP バージョンの実装があるので、必要なものを使用してください。ここでは主に、PHP の JSON 組み込みサポートについて説明します。非常にシンプルな 2 つの関数: json_encode と json_decode (シリアル化とよく似ています)。 1 つはエンコード用、もう 1 つはデコード用です。まずエンコーディングの使用方法を見てみましょう:
<?php
$arr = 配列(
'名前' => 'チェン・イーシン',
「ニック」 => 「深宇宙」、
'連絡先' => 配列(
'電子メール' => 'QQ ドットコムのシェンコン',
'ウェブサイト' => 'http://www.devdao.com',
)
);
$json_string = json_encode($arr);
$json_string をエコーします。
?> 配列を JSON 化するのは非常に簡単です。 UTF-8 以外のエンコードでは中国語の文字はエンコードできないため、gb2312 を使用して PHP コードを作成する場合は、iconv または mb を使用してコンテンツを変換する必要があることに注意してください。中国語から UTF-8 に json_encode され、上記の出力結果は次のようになります。
{"名前":"u9648u6bc5u946b","ニックネーム":"u6df1u7a7a","連絡先":{"メール":"shengong at qq dot com","ウェブサイト":"http: //www.devdao.com"}} これはシリアル化に非常に似ているとすでに言いましたが、まだ信じられていません。エンコード後はデコードする必要があります。PHP には、対応する関数 json_decode が用意されています。json_decode を実行すると、次のような操作が行われます。
<?php
$arr = 配列(
'名前' => 'チェン・イーシン',
「ニック」 => 「深宇宙」、
'連絡先' => 配列(
'電子メール' => 'QQ ドットコムのシェンコン',
'ウェブサイト' => 'http://www.devdao.com',
)
);
$json_string = json_encode($arr);
$obj = json_decode($json_string);
print_r($obj);
?> オブジェクト内のプロパティにアクセスすることは可能ですか? $obj->name は、もちろん、簡単に呼び出せるように配列に変換することもできます。
$json_string = json_encode($arr);
$obj = json_decode($json_string);
$arr = (配列) $obj;
print_r($arr); PHP はキャッシュの生成以外に、配列を直接保存するのにあまり役に立ちません。しかし、その役割は以下を見てください。 JavaScript を使用してこの文字を使用するには:
<script type="text/javascript">
var arr = {"名前":"u9648u6bc5u946b","ニックネーム":"u6df1u7a7a","連絡先":{"メール":"シェンコン at qq dot com","ウェブサイト":" http://www.devdao.com"}};
アラート(arr.name)
上記では、この文字列を変数に直接代入すると、Javascript 配列になります (専門用語では配列と呼ぶべきではありませんが、PHP の習慣のため、便宜的に配列と呼んでいます)。 )。このようにして、arr を簡単にトラバースしたり、やりたいことを何でも行うことができます。 AJAX についてはまだ触れていませんね。そうですね、考えてみてください。サーバーから返された responseText が XML ではなく JSON 文字列を使用している場合、フロントエンド Javascript がそれを処理するのに非常に便利ではないでしょうか。犬の絆創膏の使い方はこんな感じです。
実際、これを書いている時点では、データの保存形式が異なることを除けば、JSON と XML の間に大きな違いはありませんが、以下で 1 つ言及しておきます。これは XML とはほとんど関係がありませんが、JSON のより広範なアプリケーション、つまりクロスドメイン データ呼び出しを示すことができます。セキュリティの問題により、AJAX はクロスドメイン呼び出しをサポートしていません。異なるドメイン名でデータを呼び出すことは非常に面倒ですが、解決策はあります (Stone の講義でプロキシについて言及しましたが、私には理解できません)。解決されます)。クロスドメイン呼び出しを説明するには十分な 2 つのファイルを作成しました。
メインファイルindex.html
<script type="text/javascript">
関数 getProfile(str) {
var arr = str;
document.getElementById('nick').innerHTML = arr.nick;
}
</スクリプト>
<body><div id="nick"></div></body>
<scrīpt type="text/javascrīpt" src=" http://www.openphp.cn/demo/profile.php"></scrīpt > 調整されたファイル profile.php
<?php
$arr = 配列(
'名前' => 'チェン・イーシン',
「ニック」 => 「深宇宙」、
'連絡先' => 配列(
'電子メール' => 'QQ ドットコムのシェンコン',
'ウェブサイト' => 'http://www.devdao.com',
)
);
$json_string = json_encode($arr);
エコー "getProfile($json_string)";
?> 明らかに、index.html が profile.php を呼び出すと、JSON 文字列が生成され、パラメータとして getProfile に渡され、ニックネームが div に挿入されます。このようにして、クロスドメイン データ インタラクションが完了します。とても簡単なことではありませんか? JSON は非常にシンプルで使いやすいので、何を期待しているでしょうか?