ASP.NET AJAX (Atlas) 拖放(Drag Drop)功能6种实现方法总结
在Ajax程序中實現傳統桌面程序中異常簡單的拖放功能卻并不是件容易的事情。然而Web上的拖放功能又如此的讓人癡迷,所以幾乎每個成熟的Ajax類庫都提供了自己的一套實現拖放的封裝,ASP.NET AJAX (Atlas) 自然也不例外。本文將總結并簡要分析ASP.NET AJAX (Atlas) 中拖放功能的6種不同的實現方法,希望能夠幫助朋友們選出最適合實際需求的方法。
其中第1到第4種方案,在我的《ASP.NET Ajax程序設計——第I卷:服務器端ASP.NET 2.0 AJAX Extensions與ASP.NET AJAX Control Toolkit》一書中有詳細介紹(4月出版),本文中的代碼和圖示也節選自該書。第5第6種方案,在我的《ASP.NET 2.0 Ajax程序設計——第II卷:客戶端Microsoft AJAX Library》一書中將有詳細介紹(暫定7月出版)。
不過縱觀這些解決方案,我很遺憾的發現,要么是使用簡單,可定制能力差,要么就是可定制能力強,但使用起來要寫很多代碼。希望ASP.NET AJAX (Atlas) 團隊能夠再接再厲,努力把這個重要功能做得更好。或者我有哪種方法漏掉了,也請朋友們幫忙補充一下。
?
[1] 使用服務器端DragOverlayExtender或客戶端DragOverlayBehavior
服務器端的DragOverlayExtender就是靠著客戶端DragOverlayBehavior而實現的,前者是后者在服務器端的組件化封裝,所以我們將二者放在一起討論。
這個“拖放”功能很簡單,其實這只是個“拖拽”,而沒有“投放”。也就是說,你可以隨意將某個Panel在頁面中拖來拖去,不過卻沒有什么固定的地方可以“投放”,就像在Windows桌面上拖放某個窗口的位置一樣——其實用處不大,也沒有提供什么可定制能力。但它使用起來非常簡單,也支持將Panel的位置保存在Profile中。
下面是一段DragOverlayExtender的示例代碼,至于DragOverlayBehavior的用法,請查看DragOverlayExtender頁面生成的HTML代碼:
<asp:Login ID="floatLogin" BackColor="white" BorderStyle="Solid" BorderColor="black" runat="server"></asp:Login><asp:DragOverlayExtender ID="DragOverlayExtender2" Enabled="true" TargetControlID="floatLogin" runat="server" />效果如下:
?
[2] 使用服務器端DragPanel
DragPanel是ASP.NET AJAX Control Toolkit中的一個擴展器控件。其功能基本與DragOverlayExtender和DragOverlayBehavior一樣,且同樣可以保存Panel的位置信息至Profile中。不同之處在于,DragOverlayExtender和DragOverlayBehavior的拖拽實現方式中,鼠標放在整個Panel的任何部分都可以開始拖拽,而DragPanel在進行拖拽時,只有鼠標放在指定的DragHandle(類似于Windows窗口的標題欄部分)中才能開始拖拽。
對于DragHandle的擴展性和實用性,同樣不敢恭維。
下面是一段示例代碼:
<asp:Panel ID="floatPanel" CssClass="floatPanel" runat="server"> <asp:Panel ID="floatPanelHandle" CssClass="handle" runat="server"> 窗口的拖動 </asp:Panel> <div class="content"> 在Windows中,對窗口的拖動似乎成了我們習以為常的事情。 ……………… ……………… Window窗口的表現行為一樣。 </div></asp:Panel><ajaxToolkit:DragPanelExtender ID="dpe" TargetControlID="floatPanel" DragHandleID="floatPanelHandle" runat="server"></ajaxToolkit:DragPanelExtender>效果如下:
?
[3] 使用服務器端ReorderList
ASP.NET AJAX Control Toolkit中的ReorderList控件將在頁面中呈現出一個由數據綁定自動生成的條目列表。用戶可以通過鼠標拖動某一項來直接改變該列表中條目彼此之間的相對位置關系,且在拖動的過程中,ReorderList控件提供了豐富的、可定制的視覺效果。當用戶在某個位置放開鼠標之后,ReorderList控件也將同樣會自動通知與其綁定的數據源控件,以Ajax的異步或整頁回送的同步方式更新服務器端數據。
ReorderList控件的使用比較簡單(服務器端控件),功能也相當的豐富,擴展能力也不錯。不過仍稱不上最靈活,比如我們想把條目在多個ReorderList之間拖放,那么就沒辦法實現了——因此,不要指望它能實現WebPart那樣的功能。
詳細介紹請參考:《使用ASP.NET AJAX Control Toolkit中的ReorderList控件實現用鼠標拖動改變條目順序》
下面是一段示例代碼:
<ajaxToolkit:ReorderList ID="musicList" CssClass="musicList" DragHandleAlignment="Left" PostBackOnReorder="false" DataSourceID="musicDataSource" DataKeyField="Id" SortOrderField="Order" runat="server"> <ItemTemplate> <ajaxToolkit:Rating ID="rating" runat="server" CssClass="rating" StarCssClass="ratingStar" FilledStarCssClass="filledRatingStar" EmptyStarCssClass="emptyRatingStar" CurrentRating='<%# Bind("Rating") %>' MaxRating="5" ReadOnly="true"> </ajaxToolkit:Rating> </ItemTemplate> <ReorderTemplate> <div class="dragDue"> Drop Here! </div> </ReorderTemplate> <DragHandleTemplate> <asp:Label ID="lbTitle" CssClass="dragHandle" ToolTip="Drag Me!" runat="server" Text='<%# Bind("Name") %>'> </asp:Label> </DragHandleTemplate></ajaxToolkit:ReorderList>效果挺酷的:
?
[4] 使用UpdatePanel與ASP.NET AJAX中的新版本WebPart控件
ASP.NET 2.0中的WebPart相關的控件雖然非常豐富,易于使用且功能強大,我們在程序中也很需要它所提供的拖拽功能,但它卻存在著兩個致命的缺陷:
其中第一個問題可以通過ASP.NET AJAX中的新版本WebPart控件搞定,第二個問題可以通過添加UpdatePanel搞定,本來在CTP版本中的ASP.NET AJAX里面,這些功能均已經完美實現了。誰知道在最新的Futures CTP中,卻又不好用了。
既然現在已經不能用了,也就沒必要分析其優點缺點了。不過還是給出一張截圖吧,緬懷一下曾經的輝煌(注意,這可是在Firefox中啊!)……
?
[5] 使用客戶端DragDropList
DragDropList定義于ASP.NET AJAX Futures CTP中,功能非常強大,且全部在客戶端實現,給服務器端減輕了不少的壓力。使用DragDropList實現第4種解決方案中的WebPart類似的效果完全沒有問題,不過唯一讓人感到遺憾的就是,其擴展功能不是很好,用戶雖然可以隨便將某個Panel從一個區域拖到另一個區域,但拖拽的結果卻很難持久化下來……且使用起來也不是那么的容易,效率上更是不敢恭維……總之,這是個很讓人矛盾的東西,有些雞肋的感覺。
我曾經在《使用ASP.NET Atlas實現拖放(Drag & Drop)效果(下)》這篇文章中給出過DragDropList的示例程序,雖然是基于CTP版本的ASP.NET AJAX ,不過實際上并不需要多少修改就能運行于最新版本之上。感興趣的朋友可以看看,也可以到官方論壇上搜索一下相關的主題。
?
[6] 在客戶端自行實現IDragSource和IDropTarget接口
來到了這個解決方案,可以說你對ASP.NET AJAX中的拖拽實現有了一個較深入的了解。上面的DragDropList其實就是實現了IDragSource和IDropTarget接口,其中前者用來定義可以被拖拽的項目,后者用來定義可以被投放的區域。詳細理論上的說明,可以參考我的文章《使用ASP.NET Atlas實現拖放(Drag & Drop)效果(上)》,雖然目前已經有所變化,不過仍可以參考。
這種實現方案應該說是最為強大的了,想要什么功能,肯定都能實現。不過實際開發中的難度也不小——甚至可以說是相當復雜,Jeff Prosise的這篇文章《Implementing Drag-Drop in ASP.NET AJAX》給出了一個非常簡單的示例程序,感興趣想要學習的朋友不妨看看……
轉載于:https://www.cnblogs.com/dflying/archive/2007/03/26/687809.html
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的ASP.NET AJAX (Atlas) 拖放(Drag Drop)功能6种实现方法总结的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【转】C++类的sizeof大小
- 下一篇: HTTP和HTTPS的主要区别(面试常考