Dynamic Div不会从Ajax的成功中刷新



我具有一个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 />&nbsp;<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 

再次感谢所有答复!

最新更新