共用方式為


UIElement.Drop 事件

定義

輸入系統報告其下以這個項目作為置放目標的置放事件時發生。

public:
 virtual event DragEventHandler ^ Drop;
// Register
event_token Drop(DragEventHandler const& handler) const;

// Revoke with event_token
void Drop(event_token const* cookie) const;

// Revoke with event_revoker
UIElement::Drop_revoker Drop(auto_revoke_t, DragEventHandler const& handler) const;
public event DragEventHandler Drop;
function onDrop(eventArgs) { /* Your code */ }
uIElement.addEventListener("drop", onDrop);
uIElement.removeEventListener("drop", onDrop);
- or -
uIElement.ondrop = onDrop;
Public Custom Event Drop As DragEventHandler 
<uiElement Drop="eventhandler"/>

事件類型

備註

若要讓 Drop 發生並叫用處理程式,UIElement上屬於置放目標且拖放動作來源上的AllowDrop值也必須為 true

典型的處理常式會檢查DragEventArgs事件資料的Data值。

您可以呼叫StartDragAsync方法,在任何UIElement上起始拖放動作。 一旦起始動作之後,只要該元素上的AllowDrop為 true,應用程式中的任何UIElement都可以是置放目標,而拖放動作所傳遞的任何元素都可以處理DragEnterDragLeaveDragOver

Drop 是路由事件。 元素必須具有 AllowDrop為 true ,才能成為 Drop 事件來源。 如果允許事件反升至父元素,因為它未處理,則如果 Parent 元素的 AllowDroptrue ,則可以處理父元素上的事件。 不是處理常式物件或置放目標之路由中的中繼元素不需要 AllowDroptrue。 如需路由事件概念的詳細資訊,請參閱 事件和路由事件概觀

對於觸控動作、拖放動作,以及觸控動作所造成的互動特定或操作事件,元素必須可見點擊測試,才能成為事件來源,並引發與動作相關聯的事件。 UIElement.Visibility 必須是 Visible。 衍生類型的其他屬性也會影響點擊測試可見度,例如 IsEnabled。 如需詳細資訊,請參閱事件與路由事件概觀

Drop 支援將事件處理常式附加至將叫用的路由,即使事件的事件資料標示為 Handled 也一樣。 請參閱 AddHandler

特定Windows 執行階段控制項可能有 Drop 事件的類別型處理。 如果是,控制項的邏輯可能具有 OnDrop方法的覆寫。 事件通常會由類別處理常式標示為已處理,而且不會引發 Drop 事件,以供該控制項上的任何使用者程式碼處理常式處理。 如需詳細資訊,請參閱事件與路由事件概觀

與事件發生無關,某些控制項可能會使用 DragItemThemeAnimation 之類的主題動畫,以視覺化方式向使用者指出拖曳行為。

Windows 8/Windows 8.1在Windows 10之前,拖放概念的Windows 執行階段實作只允許某些控制項和輸入動作起始拖放動作。 沒有任何 StartDragAsync 或一般化 DoDragDrop 方法可允許任何 UI 元素起始拖放動作。 應用程式中拖放動作的主要來源是當您拖曳清單的專案,例如 GridView時。

適用於

另請參閱