OK、json文字列を作成しましたが、次に何をすべきかわかりませんか?
$('#submit').live('click',function(){
var dataString = '[';
$('#items tr').not(':first').each(function(){
var index = $('#items tr').index(this);
var supp_short_code=$(this).closest('tr').find('.supp_short_code').text();
var project_ref=$(this).closest('tr').find('.project_ref').text();
var om_part_no=$(this).closest('tr').find('.om_part_no').text();
var description=$(this).closest('tr').find('.description').text();
var cost_of_items=$(this).closest('tr').find('.cost_of_items').text();
var cost_total=$(this).closest('tr').find('.cost_total').text();
dataString += '{"row":"' + index + '", "supp_short_code":"' + supp_short_code + '", "project_ref":"' + project_ref + '", "om_part_no":"' + om_part_no + '", "description":"' + description + '", "cost_of_items":"' + cost_of_items + '", "cost_total_td":"' + cost_total + '"}';
});
dataString += ']';
$.ajax
({
type: "POST",
url: "order.php",
data: dataString,
cache: false,
success: function()
{
alert("Order Submitted");
}
});
});
私のphpファイルでdataStringをテキストファイルに書き込もうとしていたので、問題がないことを確認できましたが、テキストファイルには何もありませんでした!?私は何か間違ったクライアント側をやっていますか、それともPHP側、私のphpコード:
<?php
$stringData = $_POST['dataString'];
$myFile = "testFile.txt";
$fh = fopen($myFile, 'w') or die("can't open file");
fwrite($fh, $stringData);
fclose($fh);
?>
このようにデータを構築してみませんか
var postData = {};
$('#items tr').not(':first').each(function(index, value) {
var keyPrefix = 'data[' + index + ']';
postData[keyPrefix + '[supp_short_code]'] = $(this).closest('tr').find('.supp_short_code').text();
postData[keyPrefix + '[project_ref]'] = $(this).closest('tr').find('.project_ref').text();
// and so on
});
次に、AJAX呼び出しで
data: postData,
これで、PHPスクリプトはデータを多次元配列として処理できます
<?php
if (isset($_POST['data']) && is_array($_POST['data'])) {
foreach ($_POST['data'] as $row => $data) {
echo $data['supp_short_code'];
echo $data['project_ref'];
// and so on
}
}
これはそれを行う必要があります:
...
$.ajax({
type: "POST",
url: "order.php",
data: { 'dataString': dataString },
cache: false,
success: function()
{
alert("Order Submitted");
}
});
次のことを確認してみてください。
<?php
$stringData = $_POST['dataString'];
echo $stringData;
?>
まず、jsonオブジェクトを次のようにjsの文字列に変換します。
var json_string=JSON.stringify(json_object);
次に、それを文字列としてPHPに渡し、phpで次のようにデコードします。
<?php
$map = json_decode($_POST['json_string']);
?>
これがこのスレッドを見つけるのに役立つことを願っています...
問題は、存在しないPOST "dataString"という変数にアクセスしようとしていることです。 "data"プロパティを "dataString"という変数の内容に設定したからです。 post変数が「dataString」と呼ばれることを意味するものではありません。
あなたはこれを試すことができます:
data: { "dataString": dataString },
これにより、「dataString」というプロパティと実際のデータ文字列の値を持つjQuery関数にオブジェクトが渡されます。 jQueryは、このオブジェクトからすべてのプロパティ(この場合は1つのみ)を取得し、それらをHTTPリクエストの投稿変数として設定し、最終的にPHPアプリケーションに送信します。これにより、アクセスできるようになります。 $ _POST ["dataString"]呼び出しによるデータ。
スティーブ
使用時に問題があります:
url: "/folder/form.php",
そして私は使用する必要があります:
url: "folder/form.php",,