Jquery .load()不返回HTML(URL中有“”空格!)

时间:2013-01-22 14:29:20

标签: php javascript jquery ajax load

我正在为一所网上商店上学。我正在尝试建立一个jquery/ajax购物车系统。

现在这是我的jquery.load();代码

//LOAD PHP FUNCTION TO ADD TO CART
        $("#cart_page").load("cart.php?command=addToCart&productID="+productID+"&size="+size+"&amount="+amount+"&product_name="+product_name+"");

这是cart.php文件:

<?php

//ADD PRODUCTS TO CART
if($_GET['command'] == 'addToCart'){
    /********* START SESSION *********/
    session_start();

    if($_GET['productID'] == "" || $_GET['amount'] < 1 || $_GET['size'] == "" || $_GET['product_name'] == "") return;

    $max=count($_SESSION['cart']);

    if(is_array($_SESSION['cart'])){
        $max=count($_SESSION['cart']);

        for($i=0;$i<$max;$i++){
            if($_GET['productID'] == $_SESSION['cart'][$i]['productid']){
                if($_GET['size'] == $_SESSION['cart'][$i]['size'] ){
                    $product_exists = 1;
                }   
            }
        }

        if($product_exists != 1){
            $_SESSION['cart'][$max]['productid'] = $_GET['productID'];
            $_SESSION['cart'][$max]['product_name'] = $_GET['product_name'];
            $_SESSION['cart'][$max]['amount'] = $_GET['amount'];
            $_SESSION['cart'][$max]['size'] = $_GET['size'];
        }

    }else{

        $_SESSION['cart']=array();
        $_SESSION['cart'][0]['productid'] = $_GET['productID'];
        $_SESSION['cart'][0]['product_name'] = $_GET['product_name'];
        $_SESSION['cart'][0]['amount'] = $_GET['amount'];
        $_SESSION['cart'][0]['size'] = $_GET['size'];

    }

if(is_array($_SESSION['cart'])){
$max=count($_SESSION['cart']);
$cart = <<<EOD
<div class="cart_page">
    <div class="cart_product_line">
    $max
        <ul>

EOD;
        for($i=0;$i<$max;$i++){
            $arrayID = $i;
            $cart_productID = $_SESSION['cart'][$i]['productid'];
            $cart_productName = $_SESSION['cart'][$i]['product_name'];
            $cart_amount = $_SESSION['cart'][$i]['amount'];
            $cart_size = $_SESSION['cart'][$i]['size'];

$cart.= <<<EOD
            <li>$arrayID</li>
            <li>$cart_productID</li>
            <li id="$cart_productID">$cart_productName</li>
            <li class="amount">$cart_amount</li>
            <li class="size">$cart_size</li>
EOD;
        }

$cart.= <<<EOD
        </ul>
    </div>
</div>
EOD;
    }
}
echo $cart;

?>

现在它做了我想要的一切。但它在'echo $cart.php'中给出的结果并没有 不会显示在我的index.php

中 你能帮帮我吗?

PS:

如果我去:

  

cart.php命令= addToCart&安培; =的productID 28安培;量= 10安培;大小= 12&安培; PRODUCT_NAME =测试

它回馈

1
0
28
Test
10
12
HTML中的

因此脚本可以工作并返回html! 我在加载产品时也是如此,它就像魅力一样。

2 个答案:

答案 0 :(得分:1)

假设你所说的一切都是真的,那么这里可能会出现一些问题(按可能的顺序):

  1. 是否正在向另一个域发出AJAX调用?如果是这样,除非输出一些特殊的标题,否则这将不起作用。
  2. 如果您要定位的元素不存在,jQuery.load将失败。因此请仔细检查您的网页上是否有#cart_page元素。
  3. AJAX页面未返回正确的HTTP响应代码。这将在您的控制台中可见。但是,您可以通过将代码扩展到以下内容来获取更多信息:

    $("#cart_page").load("cart.php?command=addToCart&productID="+productID+"&size="+size+"&amount="+amount+"&product_name="+product_name+"", function(response, status, xhr) { if (status == "error") { console.log("Error code :" + xhr.status); // error code console.log ("Error text :" + xhr.statusText); // error text } });

  4. 其他一些JS错误。由于我们无法看到您的所有代码,因此很难看到。检查控制台是否有任何错误,并将其添加到您的第一篇文章中。

  5. (很抱歉第3点中代码的格式化。我不知道如何使用这种语法在列表中嵌入代码。缩进不起作用)

答案 1 :(得分:0)

太愚蠢......

我生成的$product_name来自数据库。

此名称中有一个“”空格。

这样做是因为它成功加载了脚本,但因为它在URL中有一个“”空格,jQuery将其视为不正确的URL,并且不会将脚本嵌入到页面中。

我觉得奇怪的是它没有给我任何错误!?

非常感谢你们帮助我!