好的,我正试图围绕如何将某些内容添加到购物车并将其显示在页面中而无需重新加载页面。
所以我试着写一些非常简单的东西,这样我就可以了解逻辑的工作原理和正确编写的方式。在我的示例中,我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;
}
?>