使用HtmlTextWriter类规范输出标签
1.尽量使用内置的方法输出标签
写过控件的人没有人会说没用过Render和RenderContents方法,其中关键的类就是用HtmlTextWriter类的一些方法把html标签呈现出来,但其写法不同,效果却相同。如输出一个下拉框:
public class DemoControl : Control
{
protected override void Render(HtmlTextWriter writer)
{
//1.以输出字符串形式输出html
/**//*
writer.Write("<select>");
writer.Write("<option value=''0''>asp.net</option>");
writer.Write("<option value=''1''>asp.net ajax</option>");
writer.Write("</select>");
*/
//2.用.net内置推荐的方法输出html
writer.RenderBeginTag(HtmlTextWriterTag.Select);
writer.AddAttribute(HtmlTextWriterAttribute.Value, "0");
writer.RenderBeginTag(HtmlTextWriterTag.Option);
writer.Write("asp.net");
writer.RenderEndTag();
writer.AddAttribute(HtmlTextWriterAttribute.Value, "1");
writer.RenderBeginTag(HtmlTextWriterTag.Option);
writer.Write("asp.net ajax");
writer.RenderEndTag();
}
}
当你熟悉这些方法后,请尽量使用这些方法
2.分段呈现标签
此方法等于为重构,当标签呈现的比较多,请不要一步到底的写下来,分部把需要的东西写在各个方法里面再组合,
如的示例三,说实话的,虽然用HtmlTextWriter的函数输出标签,但还不如直接输出字符串来的明白,一大堆的RenderBeginTag和RenderEndTag方法。请分段呈现标签,分拆函数。然后以Render开头的函数命名,这样看起来就清晰多了。
protected override void Render(HtmlTextWriter writer)
{
RenderTable(writer);
}
private void RenderTable(HtmlTextWriter writer)
{
writer.AddStyleAttribute(HtmlTextWriterStyle.BorderWidth, "0");
writer.RenderBeginTag(HtmlTextWriterTag.Table);
RnderPaymentMethod(writer);
RenderCreditCardNo(writer);
RenderCardholderName(writer);
RenderExpirationDate(writer);
RenderSubmitButton(writer);
writer.RenderEndTag();
}
3.规范标签ID命名
不要把控件的头标签把ID名字定死,防止名字重叠,可以把Control的UniqueID属性赋给ID属性,子标签也一样。可以以父标签的id为前缀,然后再加以命名。另外的好处就是可以跟前端交互,灵活性增强。
//writer.AddAttribute(HtmlTextWriterAttribute.Id, "select1");
writer.AddAttribute(HtmlTextWriterAttribute.Id, this.UniqueID);
writer.RenderBeginTag(HtmlTextWriterTag.Select);
//以父标签的id为前缀
writer.AddAttribute(HtmlTextWriterAttribute.Id, this.UniqueID+"_asp");
writer.RenderBeginTag(HtmlTextWriterTag.Option);
writer.Write("asp.net");
writer.RenderEndTag();
writer.RenderEndTag();
4.判断输出动态属性
如TextBox的Text属性,当其属性未设置时,呈现出来的标签value属性不呈现,即后端要判断,不然则要呈现value=""这项工作比较繁琐。
string text = this.Text;
if (text.Length > 0)
{
writer.AddAttribute(HtmlTextWriterAttribute.Value, text);
}
暂时就这些,想到再补充。不想把别的写进去。以后分开写。大家想到再补充。 |