Передача массива через jquery ajax в php - PullRequest
1 голос
/ 28 июля 2011

Я пытаюсь превратить входные данные формы в массив (входные имена как ключи и значения как значения) внутри jquery с помощью serializeArray () ... затем передать его в скрипт php через $ jquery.ajax .. с помощьюpost method.

$(function () {
    $("#xbut").click(function () {
        var values = {};
        $.each($(':input').serializeArray(), function (i, field) {
            values[field.name] = field.value;
        });
        $.ajax({
            type: "POST",
            url: 'ajax/NewClient.php',
            data: {
                clientdata: values
            },
            success: function (data) {
                alert(data);
            }
        });
        return false;
    });
});

У меня была эта работа вчера вечером ... но я внес некоторые изменения и теперь не могу вернуться.когда я использую преобразование массива для данных ... я не могу найти $ _POST ['clientdata'] в NewClient.php .. он просто не определен.Если я изменю свои данные ajax в строку ... я смогу найти все, что я напишу.

Есть идеи?

Ответы [ 2 ]

0 голосов
/ 28 июля 2011

Я проверил ваш скрипт, и он, кажется, работает -

<!DOCTYPE html>
<html lang="en">
    <head>
        <script class="jsbin" src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js"></script>
        <meta charset="utf-8" />
        <title></title>
    </head>
    <script>
        $(function() {
            $("#xbut").click(function() {
                var values = {};
                $.each($(':input').serializeArray(), function(i,field){
                    values[field.name] = field.value; 
                }); 
                $.ajax({
                    type: "POST",
                    url: 'PHPPage3.php',
                    data: { clientdata : values },
                    success: function(data){
                        alert(data);
                    }
                });
            return false;
            });
        });
    </script>
    <body>
    <input type="text" name="tester"/>     
    <input type="button"  value="x" id="xbut"/>   
    </body>
</html>

Тогда «PHPPage3.php» будет -

<?php
    echo $_POST['clientdata']['tester'];
?>

При нажатии кнопки на первой странице значение в поле «тестер» возвращается обратно.

0 голосов
/ 28 июля 2011

Я почти уверен, что

.serializeArray()

должно быть

.serialize()

$(function() {
    $("#xbut").click(function() {
        var values = {}; 

        $.ajax({
            type: "POST",
            url: 'ajax/NewClient.php',
            data: { clientdata : $(":input").serialize() },
            success: function(data){
                alert(data);
            }
        });
    return false;
    });
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...