使用 Anthem.NET 框架的一个调试经历

简介:Anthem 是一个很好用的 Ajax 框架,支持 ASP.NET 1.1, 2.0。
由于该框架的所有控件都继承自 ASP.NET 自身的服务器控件,保留了几乎所有这些控件的属性和行为(除了把它们的 PostBack 改为 CallBack 的无刷新调用之外)。所以学习曲线很平缓。

今天我在使用 Anthem 的时候碰到了一个比较麻烦的调试问题,记录于此。

在下面的代码中,我用了一个 Anthem.Repeater 控件。
        <asp:XmlDataSource ID="XmlDataSource2" runat="server" XPath="//NeedDocs/Doc"
        EnableCaching
="false"></asp:XmlDataSource>
        
<table class="mytable" width="100%" cellspacing="0" cellpadding="0">
          
<anthem:Repeater ID="rptNeedDocs" runat="server" DataSourceID="XmlDataSource2"
          AutoUpdateAfterCallBack
="False">
            
<HeaderTemplate>
              
<tr class="formTitle">
                
<td>
                  选中
</td>
                
<td>
                  文件、图纸名称
</td>
                
<td>
                  应送
</td>
                
<td>
                  是否原件
</td>
                
<td>
                  备注
</td>
              
</tr>
            
</HeaderTemplate>
            
<ItemTemplate>
              
<tr>
                
<td>
                  
<asp:CheckBox ID="chkDoc" runat="server" Checked="True" />
                  
<asp:HiddenField ID="hidDocId" runat="server" Value='<%# XPath("@Id") %>' />
                
</td>
                
<td>
                  
<asp:Label ID="lblDocName" runat="server" Text='<%# XPath("@Name") %>' />
                
</td>
                
<td>
                  
<asp:TextBox ID="txtQuantity" runat="server" Text='<%# XPath("@Quantity") %>' Width="30" />
                
</td>
                
<td>
                  
<asp:RadioButtonList ID="radiolist_IsOriginal" runat="server" SelectedValue='<%# XPath("@IsOriginal") %>'
                    RepeatDirection="Horizontal">
                    
<asp:ListItem Value="True">原件</asp:ListItem>
                    
<asp:ListItem Value="False">副本</asp:ListItem>
                  
</asp:RadioButtonList>
                
</td>
                
<td>
                  
<asp:TextBox ID="txtComment" runat="server" Text='<%# XPath("Comment") %>' />
                
</td>
              
</tr>
            
</ItemTemplate>
            
<FooterTemplate>
            
</FooterTemplate>
          
</anthem:Repeater>
        
</table>

这个代码在运行时,有时候会出现一个 JS 错误:“未知的运行时错误”。
而该错误只在特定情况下发生,在其他类似情况下正常。
幸亏 VS 2005 提供了非常强大的客户端脚本调试功能。我终于将错误定位到了 Anthem 产生的一行代码上:
control.innerHTML = result.controls[controlID];

查了相关资料后发现,在 IE 下,对 innerHTML 属性赋值的时候,会对所赋的值进行检查。如果不是 well formed, 则可能会出现“未知的运行时错误”。

于是我判断 anthem.Repeater 输出的 HTML 出了问题。从上面代码中高亮的两行可以看到,table 标签在 Repeater 的外面。因此 Repeater 本身输出的是一系列 tr, 并不是 well formed 的一个整体。
于是我将 table 的标签头尾分别放入 Repeater 的 HeaderTemplate 和 FooterTemplate,问题解决。
(之所以先前把 table 标签放到外面去了,是因为放在 HeaderTemplate 和 FooterTemplate 中的时候,不知道为什么 VS 的设计器不能切换到设计视图了。而改成这样可以解决问题。)

修改成功后的代码如下:
        <asp:XmlDataSource ID="XmlDataSource2" runat="server" XPath="//NeedDocs/Doc"
        EnableCaching
="false"></asp:XmlDataSource>
        
<anthem:Repeater ID="rptNeedDocs" runat="server" DataSourceID="XmlDataSource2" AutoUpdateAfterCallBack="False">
          
<HeaderTemplate>
            
<table class="mytable" width="100%" cellspacing="0" cellpadding="0">
              
<tr class="formTitle">
                
<td>
                  选中
</td>
                
<td>
                  文件、图纸名称
</td>
                
<td>
                  应送
</td>
                
<td>
                  是否原件
</td>
                
<td>
                  备注
</td>
              
</tr>
          
</HeaderTemplate>
          
<ItemTemplate>
            
<tr>
              
<td>
                
<asp:CheckBox ID="chkDoc" runat="server" Checked="True" />
                
<asp:HiddenField ID="hidDocId" runat="server" Value='<%# XPath("@Id") %>' />
              
</td>
              
<td>
                
<asp:Label ID="lblDocName" runat="server" Text='<%# XPath("@Name") %>' />
              
</td>
              
<td>
                
<asp:TextBox ID="txtQuantity" runat="server" Text='<%# XPath("@Quantity") %>' Width="30" />
              
</td>
              
<td>
                
<asp:RadioButtonList ID="radiolist_IsOriginal" runat="server" SelectedValue='<%# XPath("@IsOriginal") %>'
                  RepeatDirection="Horizontal">
                  
<asp:ListItem Value="True">原件</asp:ListItem>
                  
<asp:ListItem Value="False">副本</asp:ListItem>
                
</asp:RadioButtonList>
              
</td>
              
<td>
                
<asp:TextBox ID="txtComment" runat="server" Text='<%# XPath("Comment") %>' />
              
</td>
            
</tr>
          
</ItemTemplate>
          
<FooterTemplate>
            
</table>
          
</FooterTemplate>
        
</anthem:Repeater>

经过这次的调试,我觉得 Ajax 除了带来了界面上响应迅速的好处之外,因为引入大量 js,也增大了调试的难度,因此应用的时候还是要根据情况取舍。不能什么都上 Ajax.
posted @ 2006-08-06 03:38 木野狐(Neil Chen) 阅读(2853) 评论(13)  编辑 收藏 所属分类: .NET 综合Anthem.NET

  回复  引用  查看    
#1楼 2006-08-06 08:51 | aspnetx      
现在的ajax框架还真是多啊
  回复  引用  查看    
#2楼 2006-08-06 10:55 | Ring      
试问这些ajax框架,孰优孰差? 各自的适用场合如何?
  回复  引用    
#3楼 2006-08-06 11:16 | neuhawk1 [未注册用户]
性能如何?
  回复  引用  查看    
#4楼 [楼主]2006-08-06 11:30 | 木野狐      
@Ring
@neuhawk1

关于几种 Ajax 框架(MagicAjax, Anthem, Atlas, ...)的比较,这篇文章总结的不错。可以看看:
http://www.dotnettools.org/Blog/article.asp?id=95

  回复  引用  查看    
#5楼 2006-08-06 12:27 | 高海东      
这个我用过 ,很好用啊 ,很方便
  回复  引用    
#6楼 2006-08-06 20:18 | fds2003 [未注册用户]
这套框架很不错,我现在就用它做着一个项目!!不过这套框架在国内比较少人用,资料比较少,自带的例子比较简单,没有一些深入的、实用的例子!还有就是这套框架的源代码竟然没有注解和文档说明,这点最让我不明白,搞得我要看源代码判断里面一些类和方法的作用!遇到问题只能去官方的论坛找解决方法!!谁对这套框架了解的,大家可以交流下!
  回复  引用  查看    
#7楼 [楼主]2006-08-06 20:44 | 木野狐      
@fds2003

我只看了官方发布的例子,感觉应该是够用了。

另外有一些关于这个框架的讨论可以看这里:
http://forums.anthemdotnet.com
  回复  引用  查看    
#8楼 2006-08-07 07:15 | 兰亭      
感觉Anthem.NET比其它AJAX框架要好用得多,它不需要掌握太多的脚本就可以使用。
  回复  引用    
#9楼 2006-08-07 09:33 | neuhawk1 [未注册用户]
atlas也不错哦.

  回复  引用    
#10楼 2006-09-27 11:04 | Buck [未注册用户]
Hi,
我有一个ascx代码隐藏页有好一个[Anthem.Method] ControlBindData这个执行过程需要很久
我在Page_Load的时候
Anthem.Manager.Register(this);

Page.RegisterClientScriptBlock(GetType().FullName,
@"<script language='javascript' type='text/javascript'>
function UpdateUserControl() {
Anthem_InvokeControlMethod(
'"+ClientID+@"',
'ControlBindData',
[],
function(result){}
);
}
//UpdateUserControl();//这两中选一种
//addEvent(window, 'onload',UpdateUserControl);
</script>");

然后我把这个ascx放到一个页面(WebForm1.aspx)上。
当这个ascx里的方法还在执行时,不能点WebForm1.aspx上的其他链接;
得等ascx里的内容完全显示了,才能把链接转过去!!!

有没有什么方法解决啊?

谢谢了!
  回复  引用  查看    
#11楼 [楼主]2006-10-04 17:11 | 木野狐      
你好, 我刚看到这个回复, 过完节帮你试一下.方便的话, 贴一下源代码.
  回复  引用    
#12楼 2006-11-01 14:51 | GN [未注册用户]
咳咳
这个控件也不能放在ul里
我也中招了
  回复  引用  查看    
#13楼 2007-11-23 16:21 | jailu      
我也中招了,LZ辛苦了

标题  
姓名  
主页
Email (博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2006-09-13 00:17 编辑过
"五向定位"职业成长路线公开课(上海、南京、大连)
Google站内搜索


相关链接: