asp.net控件开发基础(1)

asp.net本身提供了很多控件,提供给我们这些比较懒惰的人使用,我认为控件的作用就在此,因为我们不想重复工作,所以要创建它,这个本身便是一个需求的关系,所以学习控件开发很有意思.

wrox网站上有本书 Professional ASP.NET 2.0 Server Control and Component Development

现在还没有出版,但网站上放出了代码,所以正好下载过来学习一下.

我看过前几章代码,环环相扣,作者用不同的知识向我们展示同一个效果,所以循序渐进的学下来很有好处.

虽然自己对控件开发还不是很熟悉,但我感觉以下几点很重要,是我自己总结的

1.了解控件之间的继承关系

  最好是先看看看System.Web.UI命名空间

(1)Control 类,所有的控件都共享的一个类,你需要去看下其里面受保护的几个方法和属性,虽然一下看不完,以后会发现常常用到这些方法

大家可以在MSDN看一下其派生类

(2)HtmlTextWriter 类

不得不了解的一个类,主要工作就是我们写的标记字符和文本输出

2.重写方法

(1) 必须继承Control类
(2) 重写Control类的Render方法,这个是必须的,因为其他控件都继承了Control 类类,所以几乎所有控件都有这个方法

3.熟悉元数据

大家都知道asp.net控件属性在编辑器上是分类的,如外观,行为,布局等,每个属性还给出了解释

简单的元数据就是起到这个作用,当然你也可以不加,但使用了元数据让人感到有亲切感,写法如

[CategoryAttribute("Appearance")]

要使用元数据,必须引用System.ComponentModel命名控件,一般你如果写组件的话,不可能不用到这样类库。具体的MSDN上有所介绍。

一.输出字符串
说多了没意思,还是来演练吧。首先你得了解HTML。来看下面代码,效果就是输出HTML到客户端

示例一

ContractedBlock.gif ExpandedBlockStart.gif
None.gifusing System;
None.gif
using System.Web.UI;
None.gif
None.gif
namespace CustomComponents
ExpandedBlockStart.gifContractedBlock.gif
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif  
/**//// <summary>
InBlock.gif  
/// Summary description for CreditCardForm
ExpandedSubBlockEnd.gif  
/// </summary>

InBlock.gif  public class CreditCardForm1 : Control
ExpandedSubBlockStart.gifContractedSubBlock.gif  
dot.gif{
InBlock.gif    
protected override void Render(HtmlTextWriter writer)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif      writer.Write(
"<table style='width:287px;height:124px;border-width:0;'>");
InBlock.gif      writer.Write(
"<tr>");
InBlock.gif      writer.Write(
"<td><strong>Payment Method</strong></td>");
InBlock.gif      writer.Write(
"<td>");
InBlock.gif      writer.Write(
"<select name='PaymentMethod' id='PaymentMethod' style='width:100%;'>");
InBlock.gif      writer.Write(
"<option value='0'>Visa</option>");
InBlock.gif      writer.Write(
"<option value='1'>MasterCard</option>");
InBlock.gif      writer.Write(
"</select>");
InBlock.gif      writer.Write(
"</td>");
InBlock.gif      writer.Write(
"</tr>");
InBlock.gif      writer.Write(
"<tr>");
InBlock.gif      writer.Write(
"<td><strong>Credit Card No.</strong></td>");
InBlock.gif      writer.Write(
"<td><input name='CreditCardNo' id='CreditCardNo' type='text' /></td>");
InBlock.gif      writer.Write(
"</tr>");
InBlock.gif      writer.Write(
"<tr>");
InBlock.gif      writer.Write(
"<td><strong>Cardholder's Name</strong></td>");
InBlock.gif      writer.Write(
"<td><input name='CardholderName' id='CardholderName' type='text' /></td>");
InBlock.gif      writer.Write(
"</tr>");
InBlock.gif      writer.Write(
"<tr>");
InBlock.gif      writer.Write(
"<td><strong>Expiration Date</strong></td>");
InBlock.gif      writer.Write(
"<td>");
InBlock.gif      writer.Write(
"<select name='Month' id='Month'>");
InBlock.gif      
for (int day = 1; day < 13; day++)
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif        
if (day < 10)
InBlock.gif          writer.Write(
"<option value='" + day.ToString() + "'>" + "0" + day.ToString() + "</option>");
InBlock.gif        
else
InBlock.gif          writer.Write(
"<option value='" + day.ToString() + "'>" + day.ToString() + "</option>");
ExpandedSubBlockEnd.gif      }

InBlock.gif      writer.Write(
"</select>");
InBlock.gif      writer.Write(
"&nbsp");
InBlock.gif      writer.Write(
"<select name='Year' id='Year'>");
InBlock.gif      
for (int year = 2005; year < 2015; year++)
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif        writer.Write(
"<option value='" + year.ToString() + "'>" + year.ToString() + "</option>");
ExpandedSubBlockEnd.gif      }

InBlock.gif      writer.Write(
"</select>");
InBlock.gif      writer.Write(
"</td>");
InBlock.gif      writer.Write(
"</tr>");
InBlock.gif      writer.Write(
"<tr>");
InBlock.gif      writer.Write(
"<td align='center' colspan='2'>");
InBlock.gif      writer.Write(
"<input type='submit' value='Submit' />");
InBlock.gif      writer.Write(
"</td>");
InBlock.gif      writer.Write(
"</tr>");
InBlock.gif      writer.Write(
"</table>");
InBlock.gif
InBlock.gif      
base.Render(writer);
ExpandedSubBlockEnd.gif    }

ExpandedSubBlockEnd.gif  }

ExpandedBlockEnd.gif}

None.gif

 

效果很简单,其实就一直在输出HTML再加几个属性,大家可以直接把代码放在App_Code文件夹里,就可自动编译,当然也可以创建web控件库.
注意要继承Control类,重写Render方法,用HtmlTextWriter类的Write输出HTML

使用控件

(1).需要先注册一下

<%@ Register TagPrefix="custom" Namespace="CustomComponents" %>

(2) 然后就使用标签输出效果

<custom:CreditCardForm1 runat="server" ID="ccf" />

下为效果图


二.改善,加入属性和元数据

可能上面做出的 控件毫无用处,但却可以让你熟悉一下步骤,上面的控件定的很死,没有定义任何属性,用处不大,下面来改造

我们来定义常用属性,然后再输出,这样我们就可以修改控件的属性了,

示例二

ContractedBlock.gif ExpandedBlockStart.gif
None.gifusing System;
None.gif
using System.Web.UI;
None.gif
using System.ComponentModel;
None.gif
None.gif
namespace CustomComponents
ExpandedBlockStart.gifContractedBlock.gif
dot.gif{
InBlock.gif  [DefaultPropertyAttribute(
"CardholderNameText")]
InBlock.gif    [ToolboxData(
@"<{0}:CreditCardForm2 
InBlock.gif    PaymentMethodText='信用卡类型' CreditCardNoText='信用卡卡号' 
InBlock.gif    CardholderNameText='信用卡持有者姓名' SubmitButtonText = '提交'  
InBlock.gif    runat='server'></{0}:CreditCardForm2>
")
InBlock.gif    ]
InBlock.gif  
public class CreditCardForm2 : Control
ExpandedSubBlockStart.gifContractedSubBlock.gif  
dot.gif{
InBlock.gif    
private string paymentMethodText = "信用卡类型";
InBlock.gif    
private string creditCardNoText = "信用卡卡号";
InBlock.gif    
private string cardholderNameText = "信用卡持有者姓名";
InBlock.gif    
private string expirationDateText = "最后使用时间";
InBlock.gif    
private string submitButtonText = "提交";
InBlock.gif
InBlock.gif    [BrowsableAttribute(
true)]
InBlock.gif    [DescriptionAttribute(
"获取和设置信用卡类型")]
InBlock.gif      [DefaultValueAttribute(
"信用卡类型")]
InBlock.gif    [CategoryAttribute(
"Appearance")]
InBlock.gif    
public virtual string PaymentMethodText
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif      
get dot.gifreturn this.paymentMethodText; }
ExpandedSubBlockStart.gifContractedSubBlock.gif      
set dot.gifthis.paymentMethodText = value; }
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    [BrowsableAttribute(
true)]
InBlock.gif    [DescriptionAttribute(
"获取或设置信用卡卡号")]
InBlock.gif    [DefaultValueAttribute(
"信用卡卡号")]
InBlock.gif    [CategoryAttribute(
"Appearance")]
InBlock.gif    
public virtual string CreditCardNoText
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif      
get dot.gifreturn this.creditCardNoText; }
ExpandedSubBlockStart.gifContractedSubBlock.gif      
set dot.gifthis.creditCardNoText = value; }
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    [BrowsableAttribute(
true)]
InBlock.gif      [DescriptionAttribute(
"获取或设置信用卡持有者姓名")]
InBlock.gif    [DefaultValueAttribute(
"信用卡持有者姓名")]
InBlock.gif    [CategoryAttribute(
"Appearance")]
InBlock.gif    
public virtual string CardholderNameText
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif      
get dot.gifreturn this.cardholderNameText; }
ExpandedSubBlockStart.gifContractedSubBlock.gif      
set dot.gifthis.cardholderNameText = value; }
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    [BrowsableAttribute(
true)]
InBlock.gif      [DescriptionAttribute(
"获取或设置最后使用时间")]
InBlock.gif      [DefaultValueAttribute(
"最后使用时间")]
InBlock.gif    [CategoryAttribute(
"Appearance")]
InBlock.gif    
public virtual string ExpirationDateText
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif      
get dot.gifreturn this.expirationDateText; }
ExpandedSubBlockStart.gifContractedSubBlock.gif      
set dot.gifthis.expirationDateText = value; }
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    [BrowsableAttribute(
true)]
InBlock.gif    [DescriptionAttribute(
"获取或设置按钮标签")]
InBlock.gif    [DefaultValueAttribute(
"提交")]
InBlock.gif    [CategoryAttribute(
"Appearance")]
InBlock.gif    
public virtual string SubmitButtonText
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif      
get dot.gifreturn this.submitButtonText; }
ExpandedSubBlockStart.gifContractedSubBlock.gif      
set dot.gifthis.submitButtonText = value; }
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    
protected override void Render(HtmlTextWriter writer)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif      writer.Write(
"<table style='width:287px;height:124px;border-width:0;'>");
InBlock.gif      writer.Write(
"<tr>");
InBlock.gif      writer.Write(
"<td>" + PaymentMethodText + "</td>");
InBlock.gif      writer.Write(
"<td>");
InBlock.gif      writer.Write(
"<select name='PaymentMethod' id='PaymentMethod' style='width:100%;'>");
InBlock.gif      writer.Write(
"<option value='0'>Visa</option>");
InBlock.gif      writer.Write(
"<option value='1'>MasterCard</option>");
InBlock.gif      writer.Write(
"</select>");
InBlock.gif      writer.Write(
"</td>");
InBlock.gif      writer.Write(
"</tr>");
InBlock.gif      writer.Write(
"<tr>");
InBlock.gif      writer.Write(
"<td>" + CreditCardNoText + "</td>");
InBlock.gif      writer.Write(
"<td><input name='CreditCardNo' id='CreditCardNo' type='text' /></td>");
InBlock.gif      writer.Write(
"</tr>");
InBlock.gif      writer.Write(
"<tr>");
InBlock.gif      writer.Write(
"<td>" + CardholderNameText + "</td>");
InBlock.gif      writer.Write(
"<td><input name='CardholderName' id='CardholderName' type='text' /></td>");
InBlock.gif      writer.Write(
"</tr>");
InBlock.gif      writer.Write(
"<tr>");
InBlock.gif      writer.Write(
"<td>" + ExpirationDateText + "</td>");
InBlock.gif      writer.Write(
"<td>");
InBlock.gif      writer.Write(
"<select name='Month' id='Month'>");
InBlock.gif      
for (int day = 1; day < 13; day++)
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif        
if (day < 10)
InBlock.gif          writer.Write(
"<option value='" + day.ToString() + "'>" + "0" + day.ToString() + "</option>");
InBlock.gif        
else
InBlock.gif          writer.Write(
"<option value='" + day.ToString() + "'>" + day.ToString() + "</option>");
ExpandedSubBlockEnd.gif      }

InBlock.gif      writer.Write(
"</select>");
InBlock.gif      writer.Write(
"&nbsp");
InBlock.gif      writer.Write(
"<select name='Year' id='Year'>");
InBlock.gif      
for (int year = 2005; year < 2015; year++)
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif        writer.Write(
"<option value='" + year.ToString() + "'>" + year.ToString() + "</option>");
ExpandedSubBlockEnd.gif      }

InBlock.gif      writer.Write(
"</select>");
InBlock.gif      writer.Write(
"</td>");
InBlock.gif      writer.Write(
"</tr>");
InBlock.gif      writer.Write(
"<tr>");
InBlock.gif      writer.Write(
"<td align='center' colspan='2'>");
InBlock.gif      writer.Write(
"<input type='submit' value='" + SubmitButtonText + "' />");
InBlock.gif      writer.Write(
"</td>");
InBlock.gif      writer.Write(
"</tr>");
InBlock.gif      writer.Write(
"</table>");
InBlock.gif
InBlock.gif      
base.Render(writer);
ExpandedSubBlockEnd.gif    }

ExpandedSubBlockEnd.gif  }

ExpandedBlockEnd.gif}

None.gif

 

上面我们接触到了元数据了,意思应该很好理解,为了测试元数据的作用,大家可以新建一个类库项目,然后把写的代码放这个项目里面,接着web网站引用这个项目,成功生成以后,你会发现工具箱已经自动帮你加上了这几个控件


 

接着你要做的工作就是拖动你需要的控件,然后你会在属性面板看到下图

然后你再结合代码中的元数据,应该就知道大概意思了.(可以根据你的理解结合MSDN看)


三.再次改善,淘汰用Write方法以字符串的方式输出HTML


接着我们继续发现问题,我们发现我们除了定义几个需要自己来修改的属性外,还是要用来大量的字符串用来输出HTML,而且容易输错.所以HtmlTextWriter类提供几个有用的方法用来代替.

(1)AddStyleAttribute方法 为标签添加样式属性
(2)AddAttribute方法        为标签添加属性
(3)RenderBeginTag          开始写入标签头 如<table....>
(4)RenderEndTag            写入标签尾部,如</table>

这里有几点需要特别注意.

一.因为其定义方式跟我们平时定义方式不同,我们平时写HTML时,是先写标签开头,再写标签的属性.如<table borderwidth="0">,然而我们在使用上面几个方法时,需要有先后顺序,我们需要先定义标签的属性和样式,然后再输出标签头.

二.标签头和尾,需一一对应.可以理解为嵌套关系.最好的理解方法就是输出代码后,查看源文件,再结合原来定义的代码来看.

还是看代码比较容易说明,由于CreditCardForm2已经定义了我们需要的属性,而我们现在要做的只是用标签的形式来替代字符串的形式,所以只需要继承CreditCardForm2类,重写Render方法即可

示例三

ContractedBlock.gif ExpandedBlockStart.gif
None.gifprotected override void Render(HtmlTextWriter writer)
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif{
InBlock.gif      writer.AddStyleAttribute(HtmlTextWriterStyle.BorderWidth, 
"0");
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Table);
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Tr);
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Td);
InBlock.gif      writer.Write(
"<strong>" + PaymentMethodText + "</strong>");
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Td);
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Name, 
"PaymentMethod");
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Id, 
"PaymentMethod");
InBlock.gif      writer.AddStyleAttribute(HtmlTextWriterStyle.Width, 
"100%");
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Select);
InBlock.gif
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Value, 
"0");
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Option);
InBlock.gif      writer.Write(
"Visa");
InBlock.gif      writer.RenderEndTag();
InBlock.gif
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Value, 
"1");
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Option);
InBlock.gif      writer.Write(
"MasterCard");
InBlock.gif      writer.RenderEndTag();
InBlock.gif
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderEndTag();
InBlock.gif
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Tr);
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Td);
InBlock.gif      writer.Write(
"<strong>" + CreditCardNoText + "</strong>");
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Td);
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Name, 
"CreditCardNo");
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Id, 
"CreditCardNo");
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Type, 
"text");
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Input);
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderEndTag();
InBlock.gif
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Tr);
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Td);
InBlock.gif      writer.Write(
"<strong>" + CardholderNameText + "</strong>");
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Td);
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Name, 
"CardholderName");
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Id, 
"CardholderName");
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Type, 
"text");
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Input);
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderEndTag();
InBlock.gif
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Tr);
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Td);
InBlock.gif      writer.Write(
"<strong>" + ExpirationDateText + "</strong>");
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Td);
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Name, 
"Month");
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Id, 
"Month");
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Select);
InBlock.gif
InBlock.gif      
for (int day = 1; day < 13; day++)
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif        writer.AddAttribute(HtmlTextWriterAttribute.Value, day.ToString());
InBlock.gif        writer.RenderBeginTag(HtmlTextWriterTag.Option);
InBlock.gif
InBlock.gif        
if (day < 10)
InBlock.gif          writer.Write(
"0" + day.ToString());
InBlock.gif        
else
InBlock.gif          writer.Write(day);
InBlock.gif
InBlock.gif        writer.RenderEndTag();
ExpandedSubBlockEnd.gif      }

InBlock.gif
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.Write(
"&nbsp;");
InBlock.gif
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Name, 
"Year");
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Id, 
"Year");
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Select);
InBlock.gif
InBlock.gif      
for (int year = 2005; year < 2015; year++)
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif        writer.AddAttribute(HtmlTextWriterAttribute.Value, year.ToString());
InBlock.gif        writer.RenderBeginTag(HtmlTextWriterTag.Option);
InBlock.gif        writer.Write(year);
InBlock.gif        writer.RenderEndTag();
ExpandedSubBlockEnd.gif      }

InBlock.gif
InBlock.gif      writer.RenderEndTag();
InBlock.gif
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderEndTag();
InBlock.gif
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Tr);
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Align, 
"center");
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Colspan, 
"2");
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Td);
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Type, 
"submit");
InBlock.gif      writer.AddAttribute(HtmlTextWriterAttribute.Value, SubmitButtonText);
InBlock.gif      writer.RenderBeginTag(HtmlTextWriterTag.Input);
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderEndTag();
InBlock.gif      writer.RenderEndTag();
ExpandedBlockEnd.gif    }

None.gif

 

实现的效果虽然一样,但上面的代码是不是漂亮很多,而且不容易输错.这也是所提倡的做法

四.未使用视图状态的后果

还是视图状态,关于视图状态大家可以参考MSDN和相关文章

看以下的示例,还是CreditCardForm3这个控件

 

None.gif if  ( ! IsPostBack)
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif      creditcardform.CardholderNameText 
= "Full Name";
InBlock.gif      creditcardform.CreditCardNoText 
= "CreditCardNo";
InBlock.gif      creditcardform.ExpirationDateText 
= "ExpirationDate";
InBlock.gif      creditcardform.PaymentMethodText 
= "Payment Options";
InBlock.gif      creditcardform.SubmitButtonText 
= "Send";
ExpandedBlockEnd.gif    }

 

首次加载效果

点击按钮以后

 

五.使用视图状态改善效果

前提条件是你未禁用视图状态

继承CreditCardForm3,改写每个属性

 

ContractedBlock.gif ExpandedBlockStart.gif
None.gifpublic override string PaymentMethodText
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif        
get dot.gifreturn ViewState["PaymentMethodText"!= null ? (string)ViewState["PaymentMethodText"] : "信用卡类型"; }
ExpandedSubBlockStart.gifContractedSubBlock.gif      
set dot.gif{ ViewState["PaymentMethodText"= value; }
ExpandedBlockEnd.gif    }

None.gif
None.gif    
public override string CreditCardNoText
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif        
get dot.gifreturn ViewState["CreditCardNoText"!= null ? (string)ViewState["CreditCardNoText"] : "信用卡卡号"; }
ExpandedSubBlockStart.gifContractedSubBlock.gif      
set dot.gif{ ViewState["CreditCardNoText"= value; }
ExpandedBlockEnd.gif    }

None.gif
None.gif    
public override string CardholderNameText
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif        
get dot.gifreturn ViewState["CardholderNameText"!= null ? (string)ViewState["CardholderNameText"] : "信用卡持有者姓名"; }
ExpandedSubBlockStart.gifContractedSubBlock.gif      
set dot.gif{ ViewState["CardholderNameText"= value; }
ExpandedBlockEnd.gif    }

None.gif
None.gif    
public override string ExpirationDateText
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif        
get dot.gifreturn ViewState["ExpirationDateText"!= null ? (string)ViewState["ExpirationDateText"] : "最后使用时间"; }
ExpandedSubBlockStart.gifContractedSubBlock.gif      
set dot.gif{ ViewState["ExpirationDateText"= value; }
ExpandedBlockEnd.gif    }

None.gif
None.gif    
public override string SubmitButtonText
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif        
get dot.gifreturn ViewState["SubmitButtonText"!= null ? (string)ViewState["SubmitButtonText"] : "提交"; }
ExpandedSubBlockStart.gifContractedSubBlock.gif      
set dot.gif{ ViewState["SubmitButtonText"= value; }
ExpandedBlockEnd.gif    }

None.gif
None.gif

以上全为个人见解,如有错误,希望大家指出.

点击下载代码

posted on 2006-07-30 20:05 Clingingboy 阅读(8847) 评论(27)   编辑  收藏 引用 网摘 所属分类: B Asp.net组件开发
463471.html?webview=1

Feedback

 re: asp.net控件开发基础(1) 2006-07-30 20:58
正打算学习控件的开发呢    
  

 re: asp.net控件开发基础(1) 2006-07-30 21:39
期待作者能通俗地把控件开发从"入门"一直介绍到"精通"!    
  

 re: asp.net控件开发基础(1) 2006-07-30 21:51
谢谢,可能我表达的并非很专业,有你们的支持,我会继续写下去的    
  

 re: asp.net控件开发基础(1) 2006-07-30 22:12
很早就想研究这个不过因为书上写的都很复杂甚至不知所云所以就搁置了好长一段时间,今天看到楼主写的使我有信心把其学明白
谢谢    
  

 re: asp.net控件开发基础(1) 2006-07-31 10:40
呵呵
很好,又学到了一些,谢谢    
  

 re: asp.net控件开发基础(1) 2006-07-31 10:51
一般都是直接使用HtmlTable, HtmlTableRow和HtmlTableCell来Render的, 使用RenderBeginTag和RenderEndTag的可读性没有那么好    
  

 re: asp.net控件开发基础(1) 2006-07-31 10:52
楼主能光看代码事例代码就能这样理解,厉害。
也想学学控件开发,希望楼主继续,谢谢:)
对了,那里下载那本书的源码,有地址吗?    
  

 re: asp.net控件开发基础(1) 2006-07-31 12:00
@一唯


不像中国的有些出版社喜欢把代码附光盘赠送,几十兆的东西,有必要吗?    
  

 asp.net控件开发基础(1) [TrackBack] 2006-07-31 12:36
http://www.cnblogs.com/Clingingboy/archive/2006/07/30/463471.html      
  

 re: asp.net控件开发基础(1) 2006-07-31 13:17
这个好呀。。 我现在就是一个大的体系搞不清楚。。    
  

 asp.net控件开发基础(2) [TrackBack] 2006-08-01 21:36
上一篇:http://www.cnblogs.com/Clingingboy/archive/2006/07/30/463471.html或许大家还对为何要重写Render方法存有疑惑,希望大家看看我...      
  

 re: asp.net控件开发基础(1) 2006-08-06 10:27
通俗易懂,太好了!    
  

 re: asp.net控件开发基础(1) 2006-09-11 15:01
我的天哪,为什么这么好的文章今天才被我发现。现在不study等到何时。希望以后楼主能多介绍这方面的内容,强烈感谢!超级支持!    
  

 re: asp.net控件开发基础(1) 2006-09-12 14:27
很好!支持!    
  

 re: asp.net控件开发基础(1) 2006-09-18 10:33
收藏再看:)    
  

 re: asp.net控件开发基础(1) 2006-09-20 20:43
非常感觉你能把这些文章拿出来分享!
:-)    
  

 re: asp.net控件开发基础(1) 2006-09-24 09:24
不错,值得学习。    
  

 re: asp.net控件开发基础(1) 2006-09-25 15:47
我看过了,ASP.net 1.0 的服务器控件开发的那本书,也懂了一些机制
但还不是很熟练,希望通过你的讲解加深认识,和大家交流。 谢谢    
  

 re: asp.net控件开发基础(1) 2006-10-11 16:07
正在学习控件开发,早来这里就好了!!感谢楼主!!    
  

 re: asp.net控件开发基础(1) 2006-10-14 13:21
请问,怎么把编译好的dll放到工具箱中?    
  

 re: asp.net控件开发基础(1) 2006-10-14 13:24
就是在你在这里:“上面我们接触到了元数据了,意思应该很好理解,为了测试元数据的作用,大家可以新建一个类库项目,然后把写的代码放这个项目里面,接着web网站引用这个项目,成功生成以后,你会发现工具箱已经自动帮你加上了这几个控件”,这里说的可以具体点吗,我是刚接触,还找不到地方呢?谢谢大虾!    
  

 re: asp.net控件开发基础(1) 2006-10-15 22:24
LZ写的这一系列的教程非常好,我从中学到了不少的东西。这里,我提个小小的建议,对于不需要UI接口的控件,可以从Components继承,并非必须从Control继承。    
  

 re: asp.net控件开发基础(1) 2006-10-15 23:07
@cnodin
谢谢你的建议,刚写这篇的时候,还不是很深入,以后有机会,把该补充的都补充一下
@沙漠野狼
如果是vs2005的话,则在工具箱处选择选项,然后浏览把dll文件文件加进去,就可以看见控件了,或者直接把dll文件放bin目录下,然后注册就可以了    
  

 re: asp.net控件开发基础(1) 2006-10-25 20:53
对于原创作者,我总是很支持!!!    
  

 re: asp.net控件开发基础(1) 2006-10-30 17:50
谢谢,我现在正需要这样的内容,受益非浅    
  

 re: asp.net控件开发基础(1) 2006-11-10 16:24
非常不错
    
  

 re: asp.net控件开发基础(1) 2006-11-20 11:41
四.未使用视图状态的后果
五.使用视图状态改善效果
//
对于这个2个,使用视图状态如果换成webcontrol控件就不需要这样.    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值