一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

使用User Control做HTML生成

  User Control大家肯定不會陌生,在使用ASP.NET的過程中,除了ASPx頁面,最常見的就莫過于ascx了。ascx是一個有獨立邏輯的組件,提供了強大的復用特性,合理使用,能夠大大提高開發效率。通過User Control直接生成HTML內容其實已經是一個比較常用的技巧了(尤其在AJAX時代),不過網絡上這方面的內容比較少,很多人還是在苦苦地拼接字符串,因此在這里我通過一個實例簡單介紹一下這個技巧。

  對一個對象(文章,圖片,音樂,etc.)進行評論是應用中最常見的功能之一。首先,我們定義一個Comment類,以及其中會用到的“獲取”方法:

public partial class Comment
{
public DateTime CreateTime { get; set; }

public string Content { get; set; }
}

public partial class Comment
{
private static List<Comment> s_comments = new List<Comment>
{
new Comment
{
CreateTime = DateTime.Parse("2007-1-1"),
Content = "今天天氣不錯"
},
new Comment
{
CreateTime = DateTime.Parse("2007-1-2"),
Content = "挺風和日麗的"
},
new Comment
{
CreateTime = DateTime.Parse("2007-1-3"),
Content = "我們下午沒有課"
},
new Comment
{
CreateTime = DateTime.Parse("2007-1-1"),
Content = "這的確挺爽的"
}
};

public static List<Comment> GetComments(int pageSize, int pageIndex, out int totalCount)
{
totalCount = s_comments.Count;

List<Comment> comments = new List<Comment>(pageSize);

for (int i = pageSize * (pageIndex - 1);
i < pageSize * pageIndex && i < s_comments.Count; i++)
{
comments.Add(s_comments[i]);
}

return comments;
}
}

  為了顯示一個評論列表,我們可以使用一個用戶控件(ItemComments.ASPx)來封裝。自然,分頁也是必不可少的:

<ASP:Repeater runat="server" ID="rptComments">
<ItemTemplate>
時間:<%# (Container.DataItem as Comment).CreateTime.ToString() %><br />
內容:<%# (Container.DataItem as Comment).Content %>
</ItemTemplate>

<SeparatorTemplate>
<hr />
</SeparatorTemplate>
<FooterTemplate>
<hr />
</FooterTemplate>

</ASP:Repeater>

<% if (this.PageIndex > 1)
{ %>
<a href="/ViewItem.ASPx?page=<%= this.PageIndex - 1 %>" title="上一頁">上一頁</a>&nbsp;
<% } %>

<% if (this.PageIndex * this.PageSize < this.TotalCount)
{ %>
<a href="/ViewItem.ASPx?page=<%= this.PageIndex + 1 %>" title="上一頁">下一頁</a>
<% } %>

  還有:

public partial class ItemComments : System.Web.UI.UserControl
{
protected override void OnPreRender(EventArgs e)
{
base.OnPreRender(e);

this.rptComments.DataSource = Comment.GetComments(this.PageSize,
this.PageIndex, out this.m_totalCount);
this.DataBind();

}

public int PageIndex { get; set; }

public int PageSize { get; set; }

private int m_totalCount;
public int TotalCount
{
get
{
return this.m_totalCount;
}
}
}

  然后再頁面(ViewItem.ASPx)中使用這個組件:

<div id="comments"><demo:ItemComments ID="itemComments" runat="server" /></div>

  以及:

public partial class ViewItem : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
this.itemComments.PageIndex = this.PageIndex;
}

protected int PageIndex
{
get
{
int result = 0;
Int32.TryParse(this.Request.QueryString["page"], out result);

return result > 0 ? result : 1;
}
}
}

  打開ViewItem.ASPx之后效果如下:

  這張頁面的功能非常簡單,那就是察看評論。當前評論的頁碼會使用QueryString的page項進行指定,然后在ViewItem.ASPx里獲取到并且設置ItemComments.ascx控件的屬性。ItemComments控件會根據自身屬性來獲取數據,進行綁定,至于顯示內容,全都定義在ascx中了。由于需要分頁功能,這個評論控件中還包含了上一頁和下一頁的鏈接,他們鏈接的目標很簡單,就是ViewItem.ASPx頁,并且加上頁碼的Query String而已。

NET技術使用User Control做HTML生成,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 成人a毛片手机免费播放 | 91se在线视频 | 国产熟睡乱子伦视频观看看 | 四虎国产永久在线精品免费观看 | 国语自产精品视频 | 欧美天天综合 | 国产91精品一区二区 | 国产精品第二页在线播放 | 色哟视频| 精品色哟哟视频在线观看 | 日本高清色惰www在线视频 | 激情五月综合婷婷 | 美女把屁股扒开让男人桶视频 | 91中文字幕在线视频 | 婷婷综合在线 | 米奇7777狠狠狠狠视频影院 | 黄视频网站免费 | 亚洲综合热 | 精品国产成人a在线观看 | 久久综合一区 | 国内精自视频品线六区免费 | 久久成人小视频 | 日本亚洲精品色婷婷在线影院 | 久久99精品国产 | 免费精品国产自产拍在 | 激情美女网站 | 中文字幕在线观看国产 | 日韩精品第1页 | 在线免费看黄网站 | 九一国产精品视频 | 欧美黑人巨大xxxxx视频 | 一区二区视频在线 | 国产一区二区高清在线 | 国产在线观看精品一区二区三区91 | 日本伊人色综合网 | 国产一区免费在线观看 | 色多多免费视频观看区一区 | 色吧五月婷婷 | 日韩午夜免费 | 精品久久久久久久久久久久久久久 | 久久国产精品高清一区二区三区 |