Ajax Control Toolkit Animation问题解决

简介:
 还记得上会提到过一个关于 Ajax Control Toolkit Animation的问题 么,就是因为Move等动画效果不支持动态参数或者说方法让我们很被动;
  问题就在于"硬编码",如何解决这个问题呢?我们用下面的场景来说明:在Repeater内容模板里面放上一个CheckBox,绑定数据源;我们的目标是
  在用户勾选一个CheckBox之后,在那条记录上飞出一个商品图片飞向购物车。
  如果我们能使用<Move Horizontal="GetH()" Vertical="GetV()" />方式那么问题就不存在了,现在我们只能<Move Horizontal="150" Vertical="-50" />!
None.gif 怎么办?我们的关键问题是确定点击的是哪一个CheckBox! 我们的解决方法基于这样两个事实:
None.gif  1.虽然我们不能使用动态参数,但是我们可以获得事件源,使用这样的方法:
ExpandedBlockStart.gif  
< script  >
InBlock.gif 
function a()
ExpandedSubBlockStart.gif
{
InBlock.gifalert(event.srcElement.value);
InBlock.gifalert(event.srcElement.id);
ExpandedBlockEnd.gif}

None.gif
</ script >
None.gif
< b > 如果这个方法可以的话,我们就可以解决动画效果的问题 </ b >< br />
None.gif15:21 2007/6/30
</ br >
None.gif
< input  id =myid  type =button  onclick =a();  value =test ></ input >
None.gif
None.gif2.现在可以取到事件源的ID了,那么怎么确定是哪一个CheckBox呢?因为绑定数据源之后页面上会生成很多CheckBox!
None.gif我们仿佛又无路可走,在查看页面源代码的时候我们找到了”救星“,请看:
None.gifid="ctl00_MainContentPlaceHolder_ResourceDataList1_DynamicRepeater1_ctl01_ctl00_DataItemCheckBox" 
None.gifid="ctl00_MainContentPlaceHolder_ResourceDataList1_DynamicRepeater1_ctl02_ctl00_DataItemCheckBox" 
None.gifid="ctl00_MainContentPlaceHolder_ResourceDataList1_DynamicRepeater1_ctl03_ctl00_DataItemCheckBox" 
None.gifid="ctl00_MainContentPlaceHolder_ResourceDataList1_DynamicRepeater1_ctl04_ctl00_DataItemCheckBox" 
None.gifid="ctl00_MainContentPlaceHolder_ResourceDataList1_DynamicRepeater1_ctl05_ctl00_DataItemCheckBox" 
None.gifid="ctl00_MainContentPlaceHolder_ResourceDataList1_DynamicRepeater1_ctl06_ctl00_DataItemCheckBox" 
None.gifid="ctl00_MainContentPlaceHolder_ResourceDataList1_DynamicRepeater1_ctl07_ctl00_DataItemCheckBox" 
None.gifid="ctl00_MainContentPlaceHolder_ResourceDataList1_DynamicRepeater1_ctl08_ctl00_DataItemCheckBox" 
None.gifid="ctl00_MainContentPlaceHolder_ResourceDataList1_DynamicRepeater1_ctl09_ctl00_DataItemCheckBox" 
None.gifid="ctl00_MainContentPlaceHolder_ResourceDataList1_DynamicRepeater1_ctl10_ctl00_DataItemCheckBox" 
None.gif     
None.gif  这是Repeater被解析之后显示的内容,每一个CheckBox都有一个ID,我们还发现了一个ct100 ct101 ct102 ct103 dot.gifct110规律,
None.gif  通过分析CheckBox的ID我们就可以确定是第几个CheckBox了!!
None.gif  
None.gif  之后呢?动画的问题还是没有解决!!!不,已经解决了,还记得Condition动画效果么?我们只需要设置一个布尔型数组就可以了;
None.gif                            
< Condition  ConditionScript ="flag[0]" >
None.gif                               
< Move  Horizontal ="150"  Vertical ="-50"   />
None.gif                            
</ Condition >  
None.gif                            
< Condition  ConditionScript ="flag[1]" >
None.gif                               
< Move  Horizontal ="160"  Vertical ="-60"   />
None.gif                            
</ Condition >                                                                                                 
None.gif
None.gif                           
< Condition  ConditionScript ="flag[2]" >
None.gif                               
< Move  Horizontal ="170"  Vertical ="-70"   />
None.gif                            
</ Condition >  
None.gif                            
< Condition  ConditionScript ="flag[3]" >
None.gif                               
< Move  Horizontal ="180"  Vertical ="-80"   />
None.gif                            
</ Condition >
None.gif                            dot.gifdot.gifdot.gifdot.gifdot.gifdot.gif.
None.gif   问题解决!
目录
相关文章
|
JavaScript 前端开发
解决js ajax跨越请求 Access control allow origin 异常
// 解决跨越请求的问题 response.setHeader("Access-Control-Allow-Origin", "*");
1338 0
|
JavaScript 前端开发 .NET
ASP.NET AJAX Progress Bar Control(转)
If you use AJAX in your web app's, you no doubt have made use of some sort of progress/status indicator that lets the user know that some operation is currently executing.
791 0
|
Web App开发 JavaScript 前端开发
Ajax Control Toolkit 34个服务器端控件(转载)
1. Accordion 【功能概述】 Accordion可以让你设计多个panel 并且一次只显示一个Panel .在页面上的显示效果就像是使用了多个CollapsiblePanels只不过每一次只展开其中一个CollapsiblePanel.Accordion控件内部包含了若干个AccordionPane,每一个AccordionPane的template里包括了对其Header和Content的定义。
1007 0
|
前端开发 .NET 开发框架
ASP.NET AJAX Control Toolkit 新扩展特性:AutoCompleteExtender
一直期待ATLAS能够提供AutoComplete的扩展特性,终于不负众望,在最新版的ASP.NET AJAX Control Toolkit 已经包含了这个特性:AutoCompleteExtender。
856 0