科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航



ZDNet>软件频道>中间件-zhiding>一键生成 Ajax Control Toolkit 标记

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

你可知道,使用Ajax扩展控件(加上本文的偷懒工具)要比单独使用普通的Server控件更加省时、省心、省力!更何况还能提高程序的易用性……

来源:博客园 2007年12月04日

关键字:标记 Toolkit Control AJAX

你可知道,使用Ajax扩展控件(加上本文的偷懒工具)要比单独使用普通的Server控件更加省时、省心、省力!更何况还能提高程序的易用性,简直就是鱼与熊掌可以兼得!总之我是已经决定在下一个项目中使用Ajax了。如果你看过本文觉得我这话是骗人的,就请尽情的抛板砖吧。

  

  让人又爱又恨的Ajax Control Toolkit

  Ajax Control Toolkit 是一套基于 ASP.NET AJAX 框架的开源控件库,里面包含了30多个非常好用的Ajax控件。这套控件最可爱的地方就是它们不是单独使用的新控件,而是作为现有服务器控件的Ajax功能扩展。也即是说,一个普普通通的使用了Server控件的页面,只要向页面中拖放几个Ajax控件,简单设置几个属性,不需要多写一行代码,你的页面立即就拥有了超酷的Ajax功能。不信?请看下面的小例子。

  1. 这就是一个使用了普通TextBox的页面

  2. 添加一个MaskedEditExtender控件,运行,普通的TextBox控件立刻就变得不一样了^_^

  3. 在添加几个普通的RangeValidator控件以及和它配套使用的Ajax 控件ValidatorCalloutExtender,我们的页面已经非常酷了。

页面的全部代码:

以下是引用片段:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="demo_page.aspx.cs" Inherits="demo_page" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>无标题页</title>
    <style type="text/css">
    .lab
    {
        font-size: 9pt;
        font-family: 宋体;
    }
    .txtbox
    {
        font-size: 9pt;
        width: 100px;
        font-family: 宋体;
    }
    </style>
</head>
<body>
    <form id="form1" runat="server">
        <table>
            <tr>
                <td>
                    <asp:Label ID="Label1" runat="server" Text="价格" CssClass="lab"></asp:Label></td>
                <td>
                    <asp:TextBox ID="price_textbox" runat="server" CssClass="txtbox"></asp:TextBox></td>
                <td>
                    <asp:Label ID="Label2" runat="server" Text="预定出货日" CssClass="lab"></asp:Label></td>
                <td>
                    <asp:TextBox ID="plan_date_textbox" runat="server" CssClass="txtbox"></asp:TextBox></td>
            </tr>
            <tr>
                <td>
                    <asp:Label ID="Label3" runat="server" CssClass="lab" Text="成本"></asp:Label></td>
                <td>
                    <asp:TextBox ID="cost_textbox" runat="server" CssClass="txtbox"></asp:TextBox></td>
                <td>
                    <asp:Label ID="Label4" runat="server" Text="实际出货日" CssClass="lab"></asp:Label></td>
                <td>
                    <asp:TextBox ID="acture_date_textbox" runat="server" CssClass="txtbox"></asp:TextBox></td>
            </tr>
        </table>
        <asp:ScriptManager ID="ScriptManager1" runat="server">
        </asp:ScriptManager>
        <ajaxToolkit:MaskedEditExtender ID="price_textbox_masker" runat="server" TargetControlID="price_textbox"
            Mask="9,999,999.99" MaskType="Number" InputDirection="RightToLeft" AcceptNegative="Left"
            DisplayMoney="Left">
        </ajaxToolkit:MaskedEditExtender>
        <ajaxToolkit:MaskedEditExtender ID="cost_textbox_masker" runat="server" TargetControlID="cost_textbox"
            Mask="9,999,999.99" MaskType="Number" InputDirection="RightToLeft" AcceptNegative="Left"
            DisplayMoney="Left">
        </ajaxToolkit:MaskedEditExtender>
        <asp:RangeValidator ID="plan_date_textbox_dv" runat="server" ControlToValidate="plan_date_textbox"
            Display="None" ErrorMessage="无效的日期" MaximumValue="3000-1-1" MinimumValue="1900-1-1"
            Type="Date"></asp:RangeValidator>
        <ajaxToolkit:ValidatorCalloutExtender ID="plan_date_textbox_dv_callout" runat="server"
            TargetControlID="plan_date_textbox_dv">
        </ajaxToolkit:ValidatorCalloutExtender>
        <asp:RangeValidator ID="acture_date_textbox_dv" runat="server" ControlToValidate="acture_date_textbox"
            Display="None" ErrorMessage="无效的日期" MaximumValue="3000-1-1" MinimumValue="1900-1-1"
            Type="Date"></asp:RangeValidator>
        <ajaxToolkit:ValidatorCalloutExtender ID="acture_date_textbox_dv_callout" runat="server"
            TargetControlID="acture_date_textbox_dv">
        </ajaxToolkit:ValidatorCalloutExtender>
    </form>
</body>
</html>

  可恨的是需要为每个TextBox添加1个或数个Ajax控件,而且这些控件除了ID和TargetControlID不同,其它部分都是相同的!对于吾辈懒人来说,这种重复性工作即使多干1分钟都会郁闷不已,而偷懒的方法也不外乎就是用程序根据模板替换ID,这一次的偷懒工具是VS2005中的宏。

  一键生成Ajax控件标记

  首先生成“价格”和“成本”两个TextBox的MaskedEditExtender控件标记。

  Step1:

  

  Step2:

  

再来生成两个日期文本框的RangeValidator和ValidatorCalloutExtender控件标记。

  Step1:

  

  Step2:

  

  经过两次复制与粘贴,就已经生成了我们想要的Ajax控件。

  

  为你的项目定制偷懒工具箱

  上面那个代码生成工具可以被非常简单、灵活地扩展。

  例如,现在想添加一个生成类似

以下是引用片段:
<ajaxToolkit:FilteredTextBoxExtender 
    ID="price_textbox_filter" runat="server"
    FilterType="Numbers"
    TargetControlID="price_textbox">
</ajaxToolkit:FilteredTextBoxExtender>

这样的标记的宏。只需要写一个只有一行代码的函数就可以了。

  Step1: 在“宏资源管理器”中的“ajaxcontroltoolkit_tag”宏项目的“Module1”上右击,点击“编辑”打开宏编辑器。

  Step2: 添加一个函数,保存。之后就可以在VS2005的宏资源管理器中看到并使用这个函数了。

  gen_number_filter函数的源代码如下:

以下是引用片段:
  ' 生成用于过滤数字的FilteredTextBoxExtender控件标记,{0}标记会被替换成复制到剪贴板中的控件的ID。
  Sub gen_number_filter()
  gen_tags("")
  End Sub

  这样你很快就可以为特定的项目定制一套专用的偷懒工具箱了。

  下载 & 安装

  现在就下载并试用一下这个ajaxcontroltoolkit_tag宏项目吧。

  Step1: 下载ajaxcontroltoolkit_tag.rar

  Step2: 解压缩,得到ajaxcontroltoolkit_tag.vsmacros这个文件(没错,整个宏项目就只有这一个文件),复制到任意一个文件夹下,当然建议把它放在D盘,因为在这个危险的星球上我们都是要随时准备格机滴^_^

  Step3: 在VS2005中打开宏资源管理器,在“宏”上右击,点击“加载宏项目...”。

  在弹出的“添加宏项目”对话框中,直接选择ajaxcontroltoolkit_tag.vsmacros这个文件添加即可。

  宏里的代码是很简单的,相信大家一看就能懂,我就不多作解释了。

查看本文来源

推广二维码
邮件订阅

如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

重磅专题