职业IT人-IT人生活圈

 找回密码
 成为会员
搜索
查看: 809|回复: 0

ASP.NET技巧:使用 Anthem.NET 框架的一个调试经历

[复制链接]
joe 发表于 2007-2-8 19:05 | 显示全部楼层 |阅读模式
  简介: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>
              <aspabel 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\">
                    <aspistItem Value=\"True\">原件</aspistItem>
                    <aspistItem Value=\"False\">副本</aspistItem>
                  </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>
                <aspabel 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\">
                  <aspistItem Value=\"True\">原件</aspistItem>
                  <aspistItem Value=\"False\">副本</aspistItem>
                </asp:RadioButtonList>
              </td>
              <td>
                <asp:TextBox ID=\"txtComment\" runat=\"server\" Text=\'<%# XPath(\"Comment\") %>\' />
              </td>
            </tr>
          </ItemTemplate>
          <FooterTemplate>
            </table>
          </FooterTemplate>
        </anthem:Repeater>

  经过这次的调试,我觉得 Ajax 除了带来了界面上响应迅速的好处之外,因为引入大量 js,也增大了调试的难度,因此应用的时候还是要根据情况取舍。不能什么都上 Ajax.


上一页
您需要登录后才可以回帖 登录 | 成为会员

本版积分规则

QQ|手机版|小黑屋|网站帮助|职业IT人-IT人生活圈 ( 粤ICP备12053935号-1 )|网站地图
本站文章版权归原发布者及原出处所有。内容为作者个人观点,并不代表本站赞同其观点和对其真实性负责,本站只提供参考并不构成任何投资及应用建议。本站是信息平台,网站上部分文章为转载,并不用于任何商业目的,我们已经尽可能的对作者和来源进行了通告,但是能力有限或疏忽造成漏登,请及时联系我们,我们将根据著作权人的要求立即更正或者删除有关内容。

GMT+8, 2024-5-10 11:02 , Processed in 0.128292 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表