AJAXを利用してDBからデータを取得しています。
サーバーからデータは取得していることはブラウザー(Egde)のデバッガーで確かめていますが、なぜか連想配列からデータが取得できません。
初歩的なミスによるものと思いますが、ご教授お願いします。
問題のコードは以下のコードです。
<head> <script src="http://code.jquery.com/jquery-3.2.1.min.js"></script> <script type="text/javascript"> $(function() { // 顧客IDに既存のデータを入力した場合はAjaxで既存データ取り出し $('button[name="save"]').click(function(){ var code = "XXXXX12345" ; $.ajax({ type: "POST", url: "dbget.php", data: {"dataid": code} , crossDomain: false, cashe: false , dataType : "json" , scriptCharaset : 'utf-8', timespan : 1000, success: function(result, textStatus, xhr) { var jsdata = JSON.stringify(xhr) ; var cvdata = JSON.parse(jsdata); var data_res = cvdata["nextid"] ; $("#result").text("[" + data_res + "]") ; }, }).fail(function(XMLHttpRequest, textStatus, errorThrown){ alert(XMLHttpRequest + " " + textStatus + errorThrown) ; }) ; }); }); </script> </head> <body> <button type="button" name="save" >登 録</button> <div id="result"></div> </body>
表示したボタンを押すと、サーバーのDBの問い合わせ結果を受け取って、一部の項目を表示する簡単なサンプルプログラムです。
しかし、結果をどうやっても"[undefined]"と表示されてしまいます。
トレースすると、”successの3つ目のパラメータ xhrにはデータが記録されており、以後、jsdata, cvdataまでは入っていることは確認しています。しかし、data_resではどうしても”undefined"になります。
念のため、呼び出し側を以下のように固定値に変更しても同じでした。
<?php $json = file_get_contents("php://input") ; // POSTデータ受け取り受け取り parse_str($json, $contents); $contents = json_decode($json, true) ; echo json_encode( array( "result" => "Passed")); ?>
回答2件
あなたの回答
tips
プレビュー