繁体   English   中英

数组从PHP到带有ajax的js

[英]array from php to js with ajax

我在服务器端有以下代码:

<?php
header('Content-Type: text/html; charset=utf-8');
require "../general.variables.php";
require "../functions_validation.php";
require "../functions_general.php";
require "../../db_con.php";

$keyword = mysql_real_escape_string($_POST["keyword"]);

$query = mysql_query("

    SELECT user_id, user_fullname, user_area, user_city, user_quarter, user_tmb
    FROM `migo_users`
    WHERE (
        user_fullname LIKE '%".$keyword."%' AND user_id NOT IN (".$superAdmins2string.")
    )
    ORDER BY tmb_set DESC, user_fname ASC
    LIMIT 7;
");

$i = 0;
while ($userInfo = mysql_fetch_array($query)) {

    $area_name = mysql_fetch_array(mysql_query("

        SELECT area_name
        FROM `migo_areas`
        WHERE
            area_id='".$userInfo['user_area']."';
    "));

    $city_name = mysql_fetch_array(mysql_query("

        SELECT city_name
        FROM `migo_cities`
        WHERE
            city_id='".$userInfo['user_city']."';
    "));

    if ($userInfo['user_quarter'] != 0) {

        $quarter_name = mysql_fetch_array(mysql_query("

            SELECT quarter_name
            FROM `migo_quarters`
            WHERE
                quarter_id='".$userInfo['user_quarter']."';
        "));
    }           
    else {
        $quarter_name['quarter_name'] = "";
    }   

    $rsl[$i]['user_id'] = $userInfo['user_id'];
    $rsl[$i]['user_fullname'] = $userInfo['user_fullname'];

    $rsl[$i]['user_area_name'] = $area_name['area_name'];
    $rsl[$i]['user_city_name'] = $city_name['city_name'];
    $rsl[$i]['user_quarter_name'] = $quarter_name['quarter_name'];

    $rsl[$i]['user_tmb'] = $userInfo['user_tmb'];

    $i++;
}

echo json_encode($rsl);
mysql_close();
?>

并且此代码在客户端:

        $.ajax({

            type : 'POST',
            url : 'php/general.ajax/header_search.php',

            //async : false,
            //cache : false,
            dataType : 'json',
            data: {
                keyword : sb_keyword
            },
            success : function(data) {

                var hs_hits = 0;

                var hs_row_nr = 1;
                var hs_results = "<div class='sb_spacing'></div><div id='sb_rows_cont'>";                   

                if (data != null) {

                    $.each(data, function(index, arr) {

                        hs_hits++;

                        if (arr['user_quarter_name'] != "") {

                            var quarter_text = "&nbsp;&nbsp;-&nbsp;&nbsp;" + arr['user_quarter_name'];

                        }
                        else {
                            var quarter_text = "";
                        }

                        hs_results = hs_results + "<a class='search_links' href=profile.php?id=" + arr['user_id'] + "><div class='sbr_row' row_nr='" + hs_row_nr + "'><div class='sbr_imgFrame'><img src='images/user_48x48/" + arr['user_tmb'] + "' alt=''></div><div class='sbr_name'>" + arr['user_fullname'].replace(regexp_hs_user_fullname, '<span>$&</span>') + "</div><div class='sbr_area'>" + arr['user_area_name'] + "</div><div class='sbr_area'>" + arr['user_city_name'] + quarter_text + "</div></div></a>";

                        hs_row_nr++;                        

                    });                     

                }

                if (hs_hits > 0) {

                    hs_results = hs_results + "</div><div class='sb_spacing'></div><a class='search_links' href='search.php?name=" + sb_keyword + "'><div id='sbr_botttom'>Se flere resultater for <span class='gay'>" + sb_keyword + "</span></div></a>";

                    $("#sb_results").html(hs_results).show();

                    searchSet = 1;
                    total_rows = hs_hits;

                    $("#sb_rows_cont > a:first .sbr_row").addClass('sbr_row_act');

                    on_a = $("#sb_rows_cont > a:first");
                    first_a = on_a;
                    last_a = $("#sb_rows_cont > a:last");
                    sb_url = $(on_a).attr('href');

                    search_navigator_init();                    

                }
                else {

                    $("#sb_results").hide();
                    searchSet = 0;                      

                }

            },
            error : function() {
                alert("ajax error");
            }
        });

一个问题,如果查询给出0个结果,并且每个函数都尝试在客户端运行,我的js代码将停止工作。

所以我想知道我在这里能做什么。

在运行每个循环之前,如何从服务器端检索点击量?

$.getJSON('ajax.php',{form data}, functon(data){
     if(data == '') return;
});

我会尝试json_encode()您的PHP数组,以允许JavaScript将其评估为本地JS对象。

echo json_encode($some_array);

请注意,json_encode()仅适用于PHP 5.2和更高版本。

您在循环中间(隐式)实例化$ rsl,但是除非您至少有一个条目,否则您不会进入循环。

在while循环上方实例化$ rsl:

...
$i = 0;
$rsl = array();
while ($userInfo = mysql_fetch_array($query)) {
...

现在,当您对其进行编码时,它是一个空数组而不是null。 这也将保存您的HTTP error_log,并且通常会更快乐。 :)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM