Web 開発では、PHP と JavaScript 間の通信が頻繁に必要になります。以下に例を示します。
JavaScript 側:
必ず xmlHttp.setRequestHeader を設定してください。そうしないと、PHP に渡されるパラメータが null になります (43 行目)。 36行目がハイライトです。
<script type="text/javascript"> function GetJson() { var xmlHttp; try { // Firefox, Opera 8.0+, Safari xmlHttp = new XMLHttpRequest(); } catch (e) { // Internet Explorer try { xmlHttp = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); } catch (e) { alert("您的浏览器不支持AJAX!"); return false; } } } xmlHttp.onreadystatechange = function() { if (xmlHttp.readyState == 4) { //alert(xmlHttp.responseText); var str = xmlHttp.responseText; document.getElementById('show').innerHTML +=str; //alert(str); var obj = eval('('+ xmlHttp.responseText +')'); //var obj = eval(({"id":"123","name":"elar","age":"21"})); alert(obj.name); } } var data = "id=123"; xmlHttp.open("POST", "testJson.php", true); xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); xmlHttp.send("id=123"); } </script> <input type="button" onclick="GetJson()" value="按我!"/> <hr /> <div id="show"></div>
PHP 側 [testJson.php]:
php ファイルはクリーンである必要があり、 タグの外側に他のタグがあってはなりません。そうしないと、eval 関数で解析できません。
<?php $res['id'] = $_POST['id']; $res['name'] = "elar"; $res['age'] = "21"; $response = "hello this is response".$_POST['id']; echo json_encode($res); ?>
概要:
js は、xmlHttp.send("id=123") を使用して PHP にデータを送信します。
PHP は、echo json_encode($res) を使用します。変数 $res の構築は JSON 仕様に準拠する必要があります)
js PHP によって送信された JSON 形式のデータを解析するには、var obj = eval('('+ xmlHttp.responseText +')');