设为首页
收藏本站
最近更新

文章搜索
本类热门

首页 >> 网络编程 >> JAVASCRIPT >> 新闻正文 [字体: ] [打印文档]
利用Atlas库为Web页面加入鼠标拖放功能(上)

文章作者:
责任编辑:rosan 录入时间:2006-12-1 22:55:42 来源:
频道声明:本频道的文章除部分特别声明禁止转载的专稿外,可以自由转载.但请务必注明出出处和原始作者 文章版权归本频道与文章作者所有.对于被频道转载文章的个人和网站,我们表示深深的谢意.

百特科技[http://www.PCbyte.cn]专业的空间、主机提供商,域名注册绝对优惠!
  摘要 有时,AJAX看上去为web页面平添了一分神秘的色彩。如果页面能够支持一些小件(例如图像和文本块)的拖放操作,那么,这明显会使访问者眼前一亮。在本文中,你会看到,利用微软Atlas你也会非常容易地在客户端实现类似的鼠标拖放功能。

  一、 引言

  你能够把一个相当酷的特征添加到你的Web应用程序中:使用户能够定制自己的页面的外观感觉。并且,在经常情况下,用户都喜欢重新安排页面部分以适合他们自己的查看习惯。不妨让我们设想这样的情景:用户导航到某一个网站,能够选择其中的一部分(例如图像、文本和其它页面小件),并且能够动态地移动它们。今天,借助于例如Atlas这样的AJAX技术,我们可以非常容易地实现这样的功能。

  当然,在ASP.NET 2.0中,你还能够使用WebParts框架来构建与此极类似的特征。然而,如果你想使用一种更简单些的方法在你的页面中加入类似于WebParts这样的特征的话,那么,Atlas为你提供了一种解决方案。

  在本文中,我将向你展示如何使你的Web页面部分"可移动";用户将能够使用基本的鼠标拖放操作来重新放置页面中的各个部分。特别是,我们可以借助ASP.NET 2.0提供的Profile服务实现页面的个性定制,并且针对每位用户保存相应的定制信息。

  二、 构建应用程序

  使用Visual Studio 2005创建一个新的Atlas应用程序,并且命名为"C:\DragandDrop"。然后,切换到Default.aspx页面的code-behind部分。

  首先,把<atlas:ScriptManager>控件的EnablePartialRendering属性设置为"true";这样以来,你的页面就能够支持部分页面更新功能:

<atlas:ScriptManager ID="ScriptManager1" runat="server" EnablePartialRendering="true" />

  接下来,把一个<atlas:UpdatePanel>控件添加到该页面,并且在它内部添加<ContentTemplate>元素。之后,再把一个面板控件添加到该<ContentTemplate>元素并且按如下所示设置它的边界风格和尺寸:

<atlas:ScriptManager ID="ScriptManager1" runat="server" EnablePartialRendering="true" />
<div>
<atlas:UpdatePanel ID="UpdatePanel1" runat="server">
 <ContentTemplate>
  <asp:Panel ID="Panel1" runat="server" BorderStyle="Solid" Height="198px" Width="194px">
  </asp:Panel>
 </ContentTemplate>
</atlas:UpdatePanel>

  现在,既然你已经在一个<atlas:UpdatePanel>控件中嵌入了一个面板控件,那么,接下来,你需要岩恍┠谌萏砑拥礁妹姘蹇丶小N耍慵瓤梢蕴砑右恍┪谋疽部梢蕴砑恿硪桓隹丶鏑alendar、ImageMap,等等。在这个示例中,我想添加一个时钟以显示一个选定时区的时间。注意,在站点ClockLink.com处提供了许多时髦的时钟,你可以容易地把它们嵌入到你的web页面里面。这些时钟能够在客户端页面每隔一秒更新自身一次而不会导致一次页面重载。在此,你将添加一个显示新泽西州时间的时钟。为了嵌入这个钟,你只需要简单地插入下列以高亮加粗显示的脚本即可:

<atlas:UpdatePanel ID="UpdatePanel1" runat="server">
<ContentTemplate>
<asp:Panel ID="Panel1" runat="server" BorderStyle="Solid" Height="198px" Width="194px">
<script rc="http://www.clocklink.com/embed.js">
</script>
<strong>Current Time in New Zealand</strong>
<script type="text/javascript" language="JavaScript">
 obj = new Object;
 obj.clockfile = "0010-Red.swf";
 obj.TimeZone = "NZT";
 obj.width = 200;
 obj.height = 200;
 obj.wmode = "transparent";
 showClock(obj);
</script>
</asp:Panel>
</ContentTemplate>
</atlas:UpdatePanel>

  至此,只要按下F5键,你就能够看到该页面的样式。图1显示了该时钟显示于一个面板控件内的情形。

利用Atlas库为Web页面加入鼠标拖放功能
图1.该屏幕快照显示了Default.aspx页面,其中的时钟每隔一秒更新一次时间。

  停止运行应用程序。现在,让我们加入一些功能使上面的面板控件包含可移动的时钟。你将使用<atlas:DragOverlayExtender>控件来达到这一目的。其实,这个<atlas:DragOverlayExtender>控件继承自另一个控件并进一步把它转变成为一个可拖动的控件。最终,你能够在Web页面上任意拖放这个控件。

  现在,请添加<atlas:DragOverlayExtender>一个控件并对它进行配置-添加一个<atlas:DragOverlayProperties>控件并且设置它的TargetControlID属性为"Panel1"。还要记住:把它的Enabled属性设置为true:

<atlas:ScriptManager ID="ScriptManager1" runat="server" EnablePartialRendering="true" />
 <atlas:DragOverlayExtender ID="DragOverlayExtender1" runat="server">
 <atlas:DragOverlayProperties TargetControlID="Panel1" Enabled="true"/>
</atlas:DragOverlayExtender>

  再次按F5键测试该应用程序。现在,你应该能够在页面上拖动这个时钟。然而,你会注意到,当你释放鼠标时,该时钟将总是返回到它的原始位置。因为你不能把该控件拖动到页面中生成的其它控件上并且你的页面上除了这个面板控件外一片空白,所以会发生这一现象。为此,你可以通过简单地在页面的<body>元素中添加下列属性来更正这个问题:

<body style="height: 100%;">

  按F5再次测试该应用程序。现在,你应该能够拖动该时钟,并把它拖放到页面的任何位置,只要你仍然在面板控件范围之内(见图2)。

利用Atlas库为Web页面加入鼠标拖放功能
图2.该屏幕快照显示了与图1相同的时钟,只不过我用鼠标把它拖到了一个新位置。

此新闻共有2页 上一页 1 2 下一页

推荐好友 | 频道收藏 | 打印文档 | 报告错误  
相关连接
·JavaScript 中的作用域
·点评2006超强JS应用网站[3]
·点评2006超强JS应用网站[2]
·点评2006超强JS应用网站[1]
·Javascript实现神奇的页面滚动控制
·利用Atlas库为Web页面加入鼠标拖放功能(下)
·利用Atlas库为Web页面加入鼠标拖放功能(上)
·AJAX:带给开发者们崭新的一片天
同一专题
·无相关专题
发表评论 版权声明:除部分特别声明不要转载,或者授权我站独家播发的文章外,大家可以自由转载我站点的原创文章,但原作者和来自我站的链接必须保留(非我站原创的,按照原来自一节,自行链接)。文章版权归我站和作者共有
转载
要求转载之图片、文件,链接请不要盗链到本站,且不准打上各自站点的水印,亦不能抹去我站点水印。
共有评论查看评论
姓名: