我具有一个JavaScript函数,该功能调用JSON的服务器,并在HTML中显示返回的数据。然后,我正在通过Ajax删除数据项,然后尝试在成功中刷新DIV,但这是行不通的。我也知道其他人遇到了同样的问题,但是我正在使用其他人用来解决但无济于事的代码。有人可以帮忙,因为这看起来很琐碎,但我只是无法正常工作,非常感谢您对此错误的建议!
javascript-
function getCartData(data){
// console.log(data);
//console.log(JSON.stringify(data.token));
//loop through JSON returned items array
for (var i = 0; i < data.items.length; i++) {
var id = data.items[i].id;
var title = data.items[i].title;
var price = data.items[i].price;
var quantity = data.items[i].quantity;
var image = data.items[i].image;
var error = 'error_'+ data.items[i].id;
var remove = 'remove_'+ data.items[i].id;
//bind JSON object to HTML
$("#result").append("<div class='column left'><img src="+ image + "width=100 height=100 style=padding:20px></div><div class='column middle' >" + " " + title + " " + price + "</div><div class='column right' ><input id='" + id + "' type=number min=1 max=10 step=1 value=" + quantity + " maxlength=2 size=2 /> <br><a id='" + remove + "' class='remove' >Remove</a><div id='" + error + "' class='error'></div></div>");
//load subtotal when page loads
$('#subtotal').html(data.items_subtotal_price);
}}
//invoke server >> bind to DOM
var script = document.createElement('script');
script.src = 'https://example.com/cart.json?callback=getCartData'
document.getElementsByTagName('head')[0].appendChild(script);
html-
<div id="cart-container">
<div id="result"></div>
</div>
ajax-
$( ".remove" ).click(function() {
var self = this;
var remove_id = $(self).attr('id').replace('remove_', '');
$.ajax({
url: "https://example.com/cart/change.json",
dataType: "jsonp",
data: {
id: remove_id,
quantity : 0
},
success: function(data) {
console.log(data); //formatted JSON data
alert('Item removed');
//TO DO - RELOAD DIV WITHOUT LOADING PAGE
// location.reload();
$('#cart-container').load(document.URL + ' #cart-container');
}
});
});
您可以回想起成功中的Cart Builder功能:
success: function(data) {
console.log(data); //formatted JSON data
alert('Item removed');
getCartData(data);
}
最终找到了一个有效的解决方案,我添加了另一个包围数据行的DIV -
var row = 'row_'+ data.items[i].id; //declare variable then assign to new div row
<div id='" + row + "'>Content HTML...</div>
jquery .remove((在ajax成功中 -
$('#row_'+ remove_id).remove(); //remove the row
再次感谢所有答复!