求知 文章 文库 Lib 视频 iPerson 课程 认证 咨询 工具 讲座 Modeler   Code  
会员   
 
  
 
 
 
偷懒秘笈之一键生成 Ajax Control Toolkit 标记
 

2010-06-23 作者:景春雷 来源:景春雷的blog

 
摘要

你可知道,使用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("<ajaxToolkit:FilteredTextBoxExtender ID=""{0}_filter"" runat=""server"" FilterType=""Numbers"" TargetControlID=""{0}"">
</ajaxToolkit:FilteredTextBoxExtender>")
End Sub

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

下载 & 安装

现在就下载并试用一下这个ajaxcontroltoolkit_tag宏项目吧。
 
Step1: 下载ajaxcontroltoolkit_tag.rar  
Step2: 解压缩,得到ajaxcontroltoolkit_tag.vsmacros这个文件(没错,整个宏项目就只有这一个文件),复制到任意一个文件夹下,当然建议把它放在D盘,因为在这个危险的星球上我们都是要随时准备格机滴^_^
Step3: 在VS2005中打开宏资源管理器,在“宏”上右击,点击“加载宏项目...”。
在弹出的“添加宏项目”对话框中,直接选择ajaxcontroltoolkit_tag.vsmacros这个文件添加即可。

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