0

我有个问题:

我有一个 JS 函数,它将数据发送到 php 脚本,然后 PHP 脚本从数据库 QUERY 返回 JSON 数据,我想获取从 PHP 脚本返回的值。

<script type="text/javascript">
    <!--

    jQuery('#wysz2').submit(function() {


        var myData = {
            "rodzaj_konta": jQuery('#rodzaj_konta').val(),
            "miejscowosc": jQuery('#miejscowosc').val()
        };

        jQuery.ajax({
            url: 'http://somescript.php?action=results',
            type: 'GET',
            data: myData,
            dataType: 'json',
            beforeSend: function() {
                jQuery('#loading').html('<p>loading...</p><img src="loading.gif" />'); //Loading image during the Ajax Request
            },
            error: function(xhr, textStatus, errorThrown) {
                alert("Error: " + (errorThrown ? errorThrown : xhr.status));
            },
            contentType: "application/json; charset=utf-8",
            success: function(data) {

                alert(data);
            }


        });

        return false;

    });
    //-->​
</script>

PHP 脚本以正确的格式返回数据,使用:

header('Content-Type: application/json');
echo json_encode($data);

当我试图提醒(数据)时,我总是得到一个空值。

如何获取此返回的 JSON 数据?

编辑:

这很奇怪,因为我已将发送方法更改为 POST。

PHP 返回 JSON:

[{"nazwa":"Test","nazwa_firmy":"Testowa","ulica":null,"numer_domy":"2A","numer_mieszkania":"11","kod_pocztowy":"00-189","miejscowosc":"Warszawa","telefon":"213-123-132","nip":"112-312-31-31","regon":"231232133","adres_www":"http:\/\/www.gogl.epl","rodzaj_uzytkownika":"serwis"}]

但是我的 JQUERY AJAX 脚本仍然返回 null。

所以我的脚本现在看起来像这样:

<script type="text/javascript">
                <!--

                    jQuery('#wysz2').submit(function() {




                    var myData = {
                       rodzaj_konta: jQuery('#rodzaj_konta').val(),
                        miejscowosc: jQuery('#miejscowosc').val()
                    };



                    jQuery.ajax({
                        url: 'http://somedomain.com/skrypt.php?action=wyniki_wyszukiwania',
                        type: 'GET',
                        data: myData,
                        dataType: 'json',
                        contentType: "application/json; charset=utf-8",
                        jsonp: "jsoncallback",
                        beforeSend:  function() {
                            jQuery('#loading').html('<p>ładowanie...</p><img src="loading.gif" />');//Loading image during the Ajax Request
                        },
                        error: function (xhr, textStatus, errorThrown) {
                            alert("Error: " + (errorThrown ? errorThrown : xhr.status));
                        },
                        success: function (data) {
                            alert(JSON.stringify(data));
                            console.log(data);
                        }

                    });

                    return false;

                });
                //-->
                </script>

有任何想法吗 ?

4

3 回答 3

0

您正在构造变量,同时以错误的方式发送对象名称的分号根据定义不存在

尝试这个

var myData = {
           rodzaj_konta: jQuery('#rodzaj_konta').val(),
            miejscowosc: jQuery('#miejscowosc').val()
        };

并在提醒您的 json 数据时尝试

alert(JSON.stringify(your_json_obj));
于 2012-12-18T08:56:11.693 回答
0

尝试提醒对象结果...

表示如果格式为 {"responseCode":"001","re​​sponseMsg":"success"} 的 json

然后alert data.responseCode

于 2012-12-18T08:56:52.773 回答
0

在你的 ajax 函数成功尝试这样的事情 var objParams1 = $.parseJSON(data); console.log(objParams1); alert(objParams1.Testowa)

于 2012-12-18T11:33:41.900 回答