web-dev-qa-db-ja.com

Jquery AJAX投稿先PHP

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);
?>
7
benhowdle89

このようにデータを構築してみませんか

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
    }
}
9
Phil

これはそれを行う必要があります:

...
$.ajax({
    type: "POST",
    url: "order.php",
    data: { 'dataString': dataString },
    cache: false,
    success: function()
        {
            alert("Order Submitted");
        }
    });

次のことを確認してみてください。

<?php
    $stringData = $_POST['dataString']; 
    echo $stringData;
?>
10
jerjer

まず、jsonオブジェクトを次のようにjsの文字列に変換します。

var json_string=JSON.stringify(json_object);

次に、それを文字列としてPHPに渡し、phpで次のようにデコードします。

<?php  
    $map = json_decode($_POST['json_string']); 
?> 

これがこのスレッドを見つけるのに役立つことを願っています...

4
SalientKnight

問題は、存在しないPOST "dataString"という変数にアクセスしようとしていることです。 "data"プロパティを "dataString"という変数の内容に設定したからです。 post変数が「dataString」と呼ばれることを意味するものではありません。

あなたはこれを試すことができます:

data: { "dataString": dataString },

これにより、「dataString」というプロパティと実際のデータ文字列の値を持つjQuery関数にオブジェクトが渡されます。 jQueryは、このオブジェクトからすべてのプロパティ(この場合は1つのみ)を取得し、それらをHTTPリクエストの投稿変数として設定し、最終的にPHPアプリケーションに送信します。これにより、アクセスできるようになります。 $ _POST ["dataString"]呼び出しによるデータ。

スティーブ

1
Steve Whitfield

使用時に問題があります:

url: "/folder/form.php",

そして私は使用する必要があります:

url: "folder/form.php",,
0
T.Todua