2017-02-09 75 views
1

我有一個應用程序,其中用戶可以從一個列表中刪除東西到另一個列表。每個清單有多個div s作爲每個都有自己的孩子的元素。我依靠父div的id來檢測執行放置的位置,但有時兒童會消耗這些事件,因爲當時光標位於其上方。有什麼辦法可以避免這種情況,爲這些孩子添加諸如droptarget="false"之類的東西?HTML使元素無效放置目標

我不認爲代碼必要(和它的太多),但無論如何:

<link rel="stylesheet" href="{{rootURL}}css/assembler.css"> 

<div class="width_match_parent box_sizing_border flex_container_row flex_align_item_start material_blue_500 padding_large"> 
    <div id="template_assembler_div_card_list" class="layout_weight_2 box_sizing_border flex_container_column padding_large"> 
     <!-- ======================================================================================== --> 
     <div id="card_1" draggable="true" class="assembler_workflow_card card blue-grey darken-1"> 
      <div class="card-content white-text" ondragover="return true"> 
       <span class="card-title">Card Title</span> 
       <p>I am a very simple card. I am good at containing small bits of information. 
        I am convenient because I require little markup to use effectively.</p> 
      </div> 
      <div class="card-action"> 
       <a href="#">This is a link</a> 
       <a href="#">This is a link</a> 
      </div> 
     </div> 
     <!-- ======================================================================================== --> 
     <div id="card_2" draggable="true" class="assembler_workflow_card card blue-grey darken-1"> 
      <div class="card-content white-text"> 
       <span class="card-title">Card Title</span> 
       <p>I am a very simple card. I am good at containing small bits of information. 
        I am convenient because I require little markup to use effectively.</p> 
      </div> 
      <div class="card-action"> 
       <a href="#">This is a link</a> 
       <a href="#">This is a link</a> 
      </div> 
     </div> 
     <!-- ======================================================================================== --> 
     <div id="card_3" draggable="true" class="assembler_workflow_card card blue-grey darken-1"> 
      <div class="card-content white-text"> 
       <span class="card-title">Card Title</span> 
       <p>I am a very simple card. I am good at containing small bits of information. 
        I am convenient because I require little markup to use effectively.</p> 
      </div> 
      <div class="card-action"> 
       <a href="#">This is a link</a> 
       <a href="#">This is a link</a> 
      </div> 
     </div> 
     <!-- ======================================================================================== --> 
     <div id="card_4" draggable="true" class="assembler_workflow_card card blue-grey darken-1"> 
      <div class="card-content white-text"> 
       <span class="card-title">Card Title</span> 
       <p>I am a very simple card. I am good at containing small bits of information. 
        I am convenient because I require little markup to use effectively.</p> 
      </div> 
      <div class="card-action"> 
       <a href="#">This is a link</a> 
       <a href="#">This is a link</a> 
      </div> 
     </div> 
     <!-- ======================================================================================== --> 
     <div id="card_5" draggable="true" class="assembler_workflow_card card blue-grey darken-1"> 
      <div class="card-content white-text"> 
       <span class="card-title">Card Title</span> 
       <p>I am a very simple card. I am good at containing small bits of information. 
        I am convenient because I require little markup to use effectively.</p> 
      </div> 
      <div class="card-action"> 
       <a href="#">This is a link</a> 
       <a href="#">This is a link</a> 
      </div> 
     </div> 
     <!-- ======================================================================================== --> 
    </div> 
    <div class="layout_weight_1 box_sizing_border flex_container_column flex_justify_content_start padding_large"> 
     <ul class="collection"> 
      <li draggable="true" class="collection-item ">Alvin</li> 
      <li draggable="true" class="collection-item ">Alvin</li> 
      <li draggable="true" class="collection-item ">Alvin</li> 
      <li draggable="true" class="collection-item ">Alvin</li> 
     </ul> 
     <p draggable="true">This is a draggable paragraph.</p> 
    </div> 
</div> 

和JS:

ANIMATION_DIRECTION_UP = -1 ; 
ANIMATION_DIRECTION_DOWN = 1 ; 

// ============================================================================================== // 
// ============================================================================================== // 
// ============================================================================================== // 

var initialized = false ; 
var dragging = false ; 
var animating = false ; 

// ============================================================================================== // 
// ============================================================================================== // 
// ============================================================================================== // 

var workflow_cards_div ; 
workflow_cards = [] ; 
var dragged_workflow_card ; 
var current_drag_target ; 
var current_animation_direction ; 

function WorkflowCard(element) { 
    this.element = element ; 
    this.width = element.outerWidth ; 
    this.height = element.outerHeight ; 
} 

WorkflowCard.prototype = { 

} 

function get_workflow_card(id) { 
    // console.log(workflow_cards.length) ; 
    for (var i = 0 ; i < workflow_cards.length ; i++) { 
     // console.log(i + ':' + workflow_cards[i].element) 
     if (workflow_cards[i].element.id == id) { 
      return workflow_cards[i] ; 
     } 
    } 
} 

function get_animation_targets(workflow_card) { 
    if (current_animation_direction == ANIMATION_DIRECTION_UP) { 
     return get_animation_workflow_cards(workflow_card, true) ; 
    } else { 
     return get_animation_workflow_cards(workflow_card, false) ; 
    } 
} 

function get_animation_workflow_cards(workflow_card, d) { 
    l = [] ; 
    var add = d ; 
    for (var i = 0 ; i < workflow_cards.length ; i++) { 
     if (workflow_cards[i].element.id == workflow_card.element.id) { 
      add = !d ; 
     } 
     if (add) { 
      l.push(workflow_cards[i]) ; 
     } 
    } 
    return l ; 
} 

// ============================================================================================== // 
// ============================================================================================== // 
// ============================================================================================== // 

function initialize() { 
    if (!initialized) { 
     initialized = true ; 
     get_all_workflow_cards() ; 
    } 
} 

function get_all_workflow_cards() { 
    $('div.assembler_workflow_card').each(function(index, element) { 
     console.log(Object.prototype.toString.call(element)) ; 
     workflow_cards.push(new WorkflowCard(element)) ; 
    }) ; 
    console.log(Object.prototype.toString.call($('#card_1'))) 
    console.log($('#card_1')) ; 
} 

function initialize_dimensions() { 
    workflow_card_div = document.getElementById('template_assembler_div_card_list') ; 
} 

// ============================================================================================== // 
// ============================================================================================== // 
// ============================================================================================== // 

document.addEventListener("drag", function(event) { 
    initialize() ; 
    if (!dragging) { 
     if (get_workflow_card(event.target.id)) { 
      dragged_workflow_card = get_workflow_card(event.target.id) ; 
      console.log('being dragged:' + dragged_workflow_card.element.id) ; 
      dragging = true ; 
     } 
    } 
}, false); 

document.addEventListener("dragover", function(event) { 
    event.preventDefault() ; 
}, false); 

document.addEventListener("dragenter", function(event) { 
    console.log('entering: ' + event.target.id) 
    target = get_workflow_card(event.target.id) ; 
    if (target == undefined) { 

    } 
    if (target.element.id != dragged_workflow_card.element.id) { 
     if (!animating) { 
      animating = true ; 
      console.log('dragenter ' + target.element.id) ; 
      position = $('#' + target.element.id).position() ; 
      center = { 
       x: position.left + target.width/2, 
       y: position.top + target.height/2 
      } 
      drag_position = { 
       x: event.screenX, 
       y: event.screenY 
      } 
      if (drag_position.y < center.y) { 
       // from above, move them down 
       console.log('from above, move them down') ; 
       current_animation_direction = ANIMATION_DIRECTION_DOWN ; 
      } else { 
       // from below, move them up 
       console.log('from below, move them up') ; 
       current_animation_direction = ANIMATION_DIRECTION_UP ; 
      } 
      animation_targets = get_animation_targets(target) ; 
      // console.log(animation_targets) ; 
      for (var i = 0 ; i < animation_targets.length ; i++) { 
       console.log(animation_targets[i]) ; 
       console.log('animating ' + animation_targets[i].element.id) 
       $('#' + animation_targets[i].element.id).animate({ 
        "top": "+=100" 
       }) ; 
       // document.getElementById(animation_targets[i].element.id).animate([ 
       // {transform: 'translateY(' + current_animation_direction * dragged_workflow_card.height + 'px)'} 
       // ], 
       // { 
       // duration: 500, 
       // iterations: 1, 
       // easing: "ease-in-out", 
       // }) ; 
      } 
     } 
    } 
}, false); 

document.addEventListener("dragleave", function(event) { 
    if (!event.target) { 
     return ; 
    } 
    target = get_workflow_card(event.target.id) ; 
    if (target != undefined) { 
     // center = target 
    } 
}, false); 

document.addEventListener("drop", function(event) { 
    event.preventDefault() ; 
    dragging = false ; 
}, false); 

// ============================================================================================== // 
// ============================================================================================== // 
// ============================================================================================== // 

$(document).ready(function() { 
}) ; 

回答

0

根據您的問題,我想你'd希望邏輯位於drop事件偵聽器中,但您似乎將其置於dragenter事件偵聽器中。無論如何,您可以通過比較事件targetcurrentTarget屬性來檢測父元素或子元素是否觸發事件。 currentTarget始終是事件偵聽器在其上定義的元素。

對於您的情況,您可能不想將拖動事件偵聽器添加到文檔中,而是將其添加到您關心的父元素中。然後,您可以通過查看event.currentTarget或通過將該ID存儲在事件偵聽器回調中來確定父元素的ID。