2

我想要一个功能,每次我从空白空间的可排序中拖动图像时,都会创建一个新的可排序。如果我将两个图像存储在可排序中,则可以拖动它们并真正创建新的可排序(灰色框)。现在我希望能够将图像从新创建的灰色框中拖出,这样如果我放在空白处,就会再次创建一个新的灰色框。这不起作用。如何将我的 uls 函数传播到动态创建的 uls?刷新似乎不起作用或我的错误在哪里?

这是我的 jsfiddle:http: //jsfiddle.net/Gy74c/6/

$( "ul" ).sortable({opacity:0.4, connectWith: 'ul',tolerance:'pointer',cursor:'move', dropOnfull: true, stop :function (event,ui){                

                                       var positionLeft=ui.position.left;
                                       var positionTop=ui.position.top;
                                       var overSortable=elementBeingHoveredOver(event.pageX, event.pageY);

                                       if (!overSortable){                                          
                                       var x=$ ("<ul id='sortable10' class='drop'></ul>");
                                       $(x).css('position','absolute');
                                       $(x).css('left',positionLeft);
                                       $(x).css('top',positionTop); 
                                       $(x).css('height','70px');                                      
                                       ui.item.appendTo(x);
                                       $(x).sortable({connectWith: 'ul'})
                                       x.appendTo('#images');
                                       $('#images').append(x);
                                       $( "ul" ).sortable({ connectWith: 'ul'});
                                       $("ul").sortable('refresh');
                                       }        

    currentID=$(this).attr('id');        
    var liNumber=document.getElementById(currentID).getElementsByTagName("li").length; 
    if (liNumber==0 &&!currentID=="sortable1"){document.getElementById(currentID).style.visibility= "hidden"}
                        }//stop-function

                     });//sortable-block
4

1 回答 1

1

我已经把它“整理”出来了;)..至少如果我理解正确的话。

http://jsfiddle.net/Gy74c/10/

$( "ul" ).sortable(options);

我已经制作了一个 var 选项,它包含可排序的所有选项。现在在停止事件中,我再次用所有选项反弹可排序。这只是没有起到神奇的作用。你利用了 ui.position .left 和 .top 绝对定位新创建的 ul.. 您必须使用 ui.offset.left 和 top 来获取元素的实际左侧和顶部.. 如果没有这个,图像将被放置在屏幕之外第二次你移动它,把它全部搞定。;)

提示:由于 var x 在声明时已经是一个 jQuery 对象,你以后不必使用 $(x) 只需 x.jQueryMethod 就可以了;)

编辑:哎呀我忘了删除 console.log() 的

于 2013-07-14T14:00:33.647 回答