2015-04-22 34 views
7

Mam problem z draggables i droppables jQuery-UI. Muszę przeciągnąć przeciągnięty wewnątrz droppable, który jest umieszczony wewnątrz iframe. Działa to dobrze, dopóki nie przewiń elementu iframe. Zrzucane współrzędne nie są aktualizowane.jQuery UI dropzone nieprawidłowe przesunięcie wewnątrz przewijanego iframe

Kwestia wykazano w tym fiddle

Używam poniżej obejście, aby przeciągnąć i upuścić do IFRAMES możliwe w pierwszej kolejności. Oblicza odpowiednie przesunięcia, ale nie używa przesunięć przewijania elementu pływającego. Próbowałem, ale nie mogłem go poprawić, aby uwzględnić przesunięcia przewijania.

// Create new object to cache iframe offsets 
$.ui.ddmanager.frameOffsets = {}; 

// Override the native `prepareOffsets` method. This is almost 
// identical to the un-edited method, except for the last part! 
$.ui.ddmanager.prepareOffsets = function (t, event) { 
    var i, j, 
     m = $.ui.ddmanager.droppables[t.options.scope] || [], 
     type = event ? event.type : null, // workaround for #2317 
     list = (t.currentItem || t.element).find(":data(ui-droppable)").addBack(), 
     doc, frameOffset; 

    droppablesLoop: for (i = 0; i < m.length; i++) { 

     //No disabled and non-accepted 
     if (m[i].options.disabled || (t && !m[i].accept.call(m[i].element[0], (t.currentItem || t.element)))) { 
      continue; 
     } 

     // Filter out elements in the current dragoged item 
     for (j = 0; j < list.length; j++) { 
      if (list[j] === m[i].element[0]) { 
       m[i].proportions().height = 0; 
       continue droppablesLoop; 
      } 
     } 

     m[i].visible = m[i].element.css("display") !== "none"; 
     if (!m[i].visible) { 
      continue; 
     } 

     //Activate the droppable if used directly from draggables 
     if (type === "mousedown") { 
      m[i]._activate.call(m[i], event); 
     } 

     // Re-calculate offset 
     m[i].offset = m[i].element.offset(); 

     // Re-calculate proportions (jQuery UI ~1.10 introduced a `proportions` cache method, so support both here!) 
     proportions = { width: m[i].element[0].offsetWidth, height: m[i].element[0].offsetHeight }; 
     typeof m[i].proportions === 'function' ? m[i].proportions(proportions) : (m[i].proportions = proportions); 

     /* ============ Here comes the fun bit! =============== */ 

     // If the element is within an another document... 
     if ((doc = m[i].document[0]) !== document) { 
      // Determine in the frame offset using cached offset (if already calculated) 
      frameOffset = $.ui.ddmanager.frameOffsets[doc]; 
      if (!frameOffset) { 
       // Calculate and cache the offset in our new `$.ui.ddmanager.frameOffsets` object 
       frameOffset = $.ui.ddmanager.frameOffsets[doc] = $(
        // Different browsers store it on different properties (IE...) 
        (doc.defaultView || doc.parentWindow).frameElement 
       ).offset(); 
      } 

      // Add the frame offset to the calculated offset 
      m[i].offset.left += frameOffset.left; 
      m[i].offset.top += frameOffset.top; 
     } 
    } 
} 

Czy ktoś ma sugestię rozwiązania problemu. Zalecenia, aby osiągnąć to samo w inny sposób, są również mile widziane.

+0

Każdy komentarz na temat odpowiedzi ??? –

+0

Działa to dobrze na safari, w Chrome występują problemy. – gwing33

Odpowiedz

3

Możesz zmienić wysokość proportions „s, w zależności od ilości przewijania w iframe. Kwota ta może zostać osiągnięty za pomocą $("iframe").contents().scrollTop() jak użyłeś go do zmiany ilości przewijania:

proportions = { 
     width: m[i].element[0].offsetWidth, 
     height: m[i].element[0].offsetHeight - $("iframe").contents().scrollTop() 
}; 

Oto DEMO.

+2

@Boyd Masz jakieś uwagi? –

+1

@falsarella Przeciągnij i upuść. Zobaczysz różnicę. –

+0

Dziękuję. To rzeczywiście rozwiązało mój problem. W międzyczasie zaimplementowałem tę samą funkcjonalność za pomocą funkcji przeciągnij i upuść HTML5, która wydaje się bardziej odpowiednim rozwiązaniem do przeciągania i upuszczania między elementami iframe. Ma również dość akceptowalną obsługę różnych przeglądarek. – Boyd