我正在用Codeigniter構建基於ajax的購物車,並且添加/刪除功能完美地工作。我現在試圖添加一個選項來添加多個項目,並不能讓它工作。Codeigniter購物車:如何使用ajax和jquery添加多個項目
這是我正在使用的標記。我不確定它是否是最好的設計,但它與非ajax函數一起工作,所以我想它應該沒問題。
<form action="cart/add_multiple" method="post" accept-charset="utf-8">
<input type="hidden" name="items[0][id]" value="3571310" />
<input type="hidden" name="items[0][qty]" value="1" />
<input type="hidden" name="items[0][price]" value="59.00" />
<input type="hidden" name="items[0][name]" value="London" />
<input type="hidden" name="items[0][heb_name]" value="לונדון" />
<input type="hidden" name="items[0][full_price]" value="59.00" />
<input type="hidden" name="items[0][discount_price]" value="59.00" />
<input type="hidden" name="items[1][id]" value="7397903" />
<input type="hidden" name="items[1][qty]" value="1" />
<input type="hidden" name="items[1][price]" value="29.00" />
<input type="hidden" name="items[1][name]" value="London Triple" />
<input type="hidden" name="items[1][heb_name]" value="לונדון טריפל" />
<input type="hidden" name="items[1][full_price]" value="29.00" />
<input type="hidden" name="items[1][discount_price]" value="29.00" />
<input type="submit" name="add_multi" value="add to cart" /></form>
的AJAX腳本如下:
$(document).ready(function() {
$(document).on("submit", "div#winning_combo_small form", function() { //catches every click on the submit button of the "add to cart" form
var items = $(this).serialize();
alert(items);
$.post(base_url + "cart/add_multiple", {items: items, ajax: '1' },
function(data){
if (data =='true')
{ // Interact with returned data
$.get(base_url + "cart", function(cart){ // Get the contents of the url cart/show_cart
$("#cart_sidebar").html(cart);
})
$.get(base_url + "cart/count_items", function(items){
$("#cart_items").html(items);
})
}
});
return false;
})
});
但它不工作,因爲add_multiple
函數接收數據作爲一個字符串,而不是一個數組。我是否需要以某種方式解碼數據才能將其轉換爲數組?希伯來字符是否妨礙了整個過程?
我應該說,以常規方式發佈表單時,如果沒有ajax,這些項目將被添加到購物車,並且一切正常。那麼普通帖子和ajax帖子有什麼區別呢?