5

好的,我正试图围绕如何将某些内容添加到购物车并将其显示在页面中而无需重新加载页面。

所以我试着写一些非常简单的东西,这样我就可以了解逻辑的工作原理和正确编写的方式。在我的示例中,我div在页面中有一个session['cart']和一个下拉菜单。

一个值为“red”的选项,另一个值为“blue”的选项。当我选择值为“red”的选项时,我希望“red”显示在位于 body 标记之后的 div 中session['cart']。当我选择值为“蓝色”的选项时,我希望“蓝色”显示在session['cart'].

我正在尝试通过ajax发布到名为'cart_update.php'. 我已经为这个更高级的模型苦苦挣扎了一周,我认为写一些简单的东西是个好主意,这样我就可以真正理解和了解真正发生的事情。非常感谢任何帮助!

这是我的代码,我知道它的出路。我只是想学习。

索引.php

        <?php session_start(); ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<style type="text/css">
body {
    margin-top: 200px;
}
</style>
</head>

<body>
<div align="left" style="display:block;width:200px;height:200px;background:#ccc;border:solid 1px #009966;">Color Chosen<br /><?php echo $_SESSION['cart']; ?></div>

<div align="center"><form method="post" action="">
<select id="color-selection">
<option value="red">Red</option>
<option value="blue">Blue</option>
</select>
</div>
<script type="text/javascript">
$(document).ready(function(){
    $("#color-selection").on("change", function(event){
        var color = $("#color-selection").val();
        var add = "add";
        var dataString = {color: color, type: add}; //JSON-formatted string
        $.ajax({  
            type: "POST",  
            url: "cart_update.php",  
            data: dataString
        });
    });
});
</script>

</body>
</html>

这是我的 cart_update.php

<?php
session_start();
$type = json_decode($_POST['type']);
if(isset($_POST["type"]) && $_POST["type"]== $type)
{
    $color = json_decode($_POST['color']);   
    $_SESSION['cart'] = $color;
}
?>
4

1 回答 1

0

当您不告诉我们您收到什么错误/警告时,很难说出什么不起作用。您应该查看您的 js 控制台(使用 firebug 或其他调试工具)

不过看看你的代码,我看到了一些东西..

$(document).ready(function(){
    $(".add_to_cart").onClick(function(){
         var dataString = "color=" + color;
          $.ajax({  
          type: "POST",  
          url: "cart_update.php",  
          data: dataString
          });
    });
});

onClick 在这种情况下不起作用。改为使用on()http://api.jquery.com/on/ 第二件事是发送数据时应该使用 JSON 格式的字符串。

$(document).ready(function(){
    $(".add_to_cart").on("click", function(event){
        var dataString = {color: color}; //JSON-formatted string
        $.ajax({  
            type: "POST",  
            url: "cart_update.php",  
            data: dataString
        });
    });
});

在您的 html 中,您有几个带有定义颜色的表单的隐藏字段。而不是这种方法,我会在一个表单中创建一个选择列表,这样可以很容易地获取颜色的值,并且您不必为每种颜色创建一个新表单。

像这样的东西:

<select id="color-selection">
<option value="red">Red</option>
<option value="blue">Blue</option>
</select>

然后在您的 js 中,您可以通过执行以下操作来选择颜色:

color = $("#color-selection").val();

要在 ajax 调用完成时获取响应值,请使用 done()-callback。分配返回类型也是一个好习惯。

$(document).ready(function(){
    $(".add_to_cart").on("click", function(event){
        color = $("#color-selection").val();
        var dataString = {color: color}; //JSON-formatted string
        $.ajax({  
            type: "POST",  
            url: "cart_update.php",  
            data: dataString,
            dataType: "json" //This indicates the expected return-type
        }).done(function(data) {
                $("#thecoloris").html(data.color); //response from php. Set the color in the div id="thecolorid"
       }); 

    });
});

在您的 php 代码中,您必须解码 json 数据:

<?php
session_start();
if(isset($_POST["type"]) && $_POST["type"]=='add')
{
    $color = json_decode($_POST['color']);   
    $_SESSION['cart'] = $color;
}
echo $_POST['color']; //Output color (that is sent to this php through ajax) - This acts as the return value data in the ajax-function done()
?>

通常输出的值应该使用 json_encode($variable) 以 json 格式编码,但在这种情况下 $_POST['color'] 已经是 json 格式,因为它是从 js 以 json 格式发送到 php 的。

于 2013-07-27T22:58:48.360 回答