如何使动态创建的元素接受可拖放元素
How to make a dynamically created element accept droppable elements
我有下面的代码,我在其中使用ajax结果创建动态元素。
function getBillInformation(Status,billingDate,User){
var parent = "";
var status = "";
switch(Status){
case "OPEN":
parent = $('#tab-1');
status = "O";
break;
case "SETTLED":
parent = $('#tab-2');
status = "S";
break;
case "CANCEL":
parent = $('#tab-3');
status = "C";
break;
}
var billList = parent.find('#bill-list').first();
var bill = parent.find('.bill').first();
var billItemList = parent.find('.bill-item-list').first();
var billItem = parent.find('.bill-item').first();
var billPanel = parent.find('#bill-panel').first();
var jsonObject = "billStatus=" + status + "&billingDate=" + billingDate + "&user=" + User;
ajaxCall("/getBillingInformation","POST",jsonObject,function(response){
billPanel.empty();
billItemList.find('.bill-item').each(function(){
$(this).remove();
})
for(var i = 0; i < response.bills.length; i++){
var clone = bill.clone();
clone.attr('id', response.bills[i].billId);
clone.find('.bill-number').html(response.bills[i].billNo);
clone.find('.amount').html(response.bills[i].billTotal + " USD");
clone.find('.room-number').html(response.bills[i].roomNo);
clone.find('.table-name').html(response.bills[i].tableNo);
if(response.bills[i].itemsList.length != 0){
for(var j = 0; j < response.bills[i].itemsList.length; j++){
var billItemClone = billItem.clone();
billItemClone.find('.bill-item-name-right').html(response.bills[i].itemsList[j].amount);
billItemClone.find('.bill-item-amount').html(response.bills[i].itemsList[j].qty);
var total = (response.bills[i].itemsList[j].amount) * (response.bills[i].itemsList[j].qty);
billItemClone.find('.bill-item-price').html(total + ".00 USD");
billItemClone.draggable({
revert : true,
zIndex: 1,
containment: "window",
opacity: 0.5,
cursor: "move",
helper: function() { return $(this).clone().appendTo('body').show(); }
});
clone.find('.bill-item-list').prepend(billItemClone);
}
}
billPanel.prepend(clone);
}
});
}
现在我需要使bill-item-list
元素可掉落。我编写了接受可拖放元素的代码。这是代码
$('.bill-item-list').droppable({
accept: '.item',
drop: function( event, ui ) {
var clone = bill.clone();
var droppable = $(this);
var jsonObject = 'itemId=' + ui.draggable.attr('id') + '&billId=' + $(this).parent().attr('id');
$.ajax({
url: "/addItemToBill",
type: "POST",
data: jsonObject,
dataType: "json",
beforeSend: function(x) {
if(x && x.overrideMimeType) {
x.overrideMimeType("application/json;charset=UTF-8");
}
},
success: function(result){
if(result.status = true){
clone.find('.bill-item-name-left').html(ui.draggable.find('.item-name').children('h4').html());
clone.find('.bill-item-name-right').html(ui.draggable.find('.item-price').children('h4').html());
clone.find('.bill-item-price').html(ui.draggable.find('.item-price').children('h4').html() + ".00 USD" );
clone.find('.bill-item-amount').html("1");
if(droppable.height() > 300){
droppable.css('overflow-y','scroll');
droppable.css('height', '320px')
}
clone.draggable({
revert : true,
zIndex: 1,
containment: "window",
opacity: 0.5,
cursor: "move",
helper: function() { return $(this).clone().appendTo('body').show(); }
});
clone.insertBefore(droppable.find('.item-drop-point')).hide().fadeIn("slow");
}
}
});
}
});
问题是我试图使元素可降,当我创建它!但是有一个ajax调用正在进行,当一个项目已经被删除!所以谁能给我一个主意,使这个动态元素可降
你需要分离函数'drop' even处理程序,然后对于动态元素,你需要再次绑定可掉落插件。
注意:你需要取消绑定以前应用的插件。
E。g:
function drop_handler(){
----
$('.bill-item-list').unbind('droppable');
events() // once again apply your droppable plugin
}
function events(){
$('.bill-item-list').droppable({
accept: '.item',
drop: drop_handler
})
}
相关文章:
- Jquery 拖放允许 2 个元素
- JavaScript拖放 - 防止元素拖放到另一个可拖放的元素中
- 区分不同的可拖放元素(jQuery 拖放)
- JavaScript/jQuery在两个iframe之间拖放元素
- 在单独的容器中拖放,并调整放置的元素的位置
- 拖放与拖动不同的元素
- 拖放具有触摸支持的元素
- 防止在使用JS拖放时将其放入子元素内
- EaselJS / canvas在拖放过程中更改元素焦点
- 是否可以使用 JavaScript 在 WebBrowser 中拖动 WPF 元素和句柄拖放
- 防止HTML5拖放功能多次放置同一元素
- 花式树拖放 - 获取当前元素
- 由javascript创建的HTML5拖放元素:
- 拖放 - 元素不会拖放
- 是否有最适合“拖放”Web应用程序的元素
- 在 JQuery UI 拖放后查找列表中元素的索引
- 使拖放的元素可放置,同时仍可拖动
- 使用HTML5拖放,有没有办法在保持拖动流的同时隐藏元素
- 如何使用HTML2canvas截取拖放元素的屏幕截图
- 从子元素拖放父元素