婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 動(dòng)態(tài)加載用戶控件至DataList并為用戶控件賦值實(shí)例演示

動(dòng)態(tài)加載用戶控件至DataList并為用戶控件賦值實(shí)例演示

熱門標(biāo)簽:玉林市機(jī)器人外呼系統(tǒng)哪家好 電話機(jī)器人軟件銷售工作 南陽(yáng)外呼系統(tǒng)定制化 預(yù)測(cè)式外呼系統(tǒng)使用說明 合肥電銷外呼系統(tǒng)哪家公司做的好 申請(qǐng)400電話手續(xù) 蘋果手機(jī)凱立德地圖標(biāo)注 同安公安400電話怎么申請(qǐng)流程 百度ai地圖標(biāo)注
為了實(shí)現(xiàn)這個(gè)演示,Insus.NET使用通用的新聞例子,它類別(目錄)以及文章。在一個(gè)頁(yè)面,顯示所有類別,每個(gè)目錄下顯示最新幾條新聞。

效果如下:
目錄是用DataList控件顯示,而文章標(biāo)題列表是一個(gè)用戶控件顯示,這個(gè)用戶控件將動(dòng)態(tài)被加入至DataList。
復(fù)制代碼 代碼如下:

View Code
asp:Repeater ID="Repeater1" runat="server" OnItemDataBound="Repeater1_ItemDataBound">
HeaderTemplate>
table cellpadding="5" cellspacing="0" width="100%">
/HeaderTemplate>
ItemTemplate>
tr style="height: 30px; line-height: 10px;">
td>
$
/td>
td>
asp:HyperLink ID="HyperLink1" runat="server" NavigateUrl='%# "~/ArticleView.aspx?ID=" Eval("Article_nbr")%>' ToolTip='%# Eval("Subject")%>' Target="_blank">/asp:HyperLink>
/td>
td>
%# objInsusDateTimeUtility.GetDateTime(Eval("PublicDate"), "yyyy-MM-dd")%>
/td>
/tr>
/ItemTemplate>
FooterTemplate>
/table>
/FooterTemplate>
/asp:Repeater>

復(fù)制代碼 代碼如下:

View Code
View Code
Imports System.Data
Imports Insus.NET
Partial Class AscxControls_ArticleList
Inherits System.Web.UI.UserControl
Implements ISetValue '繼承接口
Dim objArticle As New Article()
Protected objInsusDateTimeUtility As New InsusDateTimeUtility()
Private _DataSource As Object
Private _SubjectLength As Integer = 20
Public WriteOnly Property SubjectLength() As Integer
Set(ByVal value As Integer)
_SubjectLength = value
End Set
End Property
Protected Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs) Handles Me.Load
Data_Binding()
End Sub
'綁定數(shù)據(jù)至Repeater控件
Private Sub Data_Binding()
Me.Repeater1.DataSource = _DataSource
Me.Repeater1.DataBind()
End Sub
Protected Sub Repeater1_ItemDataBound(ByVal sender As Object, ByVal e As RepeaterItemEventArgs)
Dim objDrv As DataRowView = DirectCast(e.Item.DataItem, DataRowView)
If e.Item.ItemType = ListItemType.AlternatingItem OrElse e.Item.ItemType = ListItemType.Item Then
If e.Item.FindControl("HyperLink1") IsNot Nothing Then
Dim LinkSubject As HyperLink = DirectCast(e.Item.FindControl("HyperLink1"), HyperLink)
If objDrv("Subject").Length > _SubjectLength Then
LinkSubject.Text = objDrv("Subject").Substring(0, _SubjectLength) "..."
Else
LinkSubject.Text = objDrv("Subject").ToString()
End If
End If
End If
End Sub
'實(shí)現(xiàn)接口
Public Sub SetValue(str As Object) Implements ISetValue.SetValue
Me._DataSource = str
End Sub
End Class

上面用戶控件中,有一個(gè)接口:
復(fù)制代碼 代碼如下:

ISetValue
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Insus.NET
{
public interface ISetValue
{
void SetValue(object obj);
}
}

顯示目錄:
復(fù)制代碼 代碼如下:

View Code
asp:DataList ID="DataListCatalog" runat="server" RepeatColumns="2" RepeatDirection="Horizontal" DataKeyField="Catalog_nbr" OnItemDataBound="DataListCatalog_ItemDataBound">
ItemTemplate>
div style="padding:2PX; height:25px; background-color:#cbfb25; font-weight:bold; line-height:25PX;">
%# Eval("CatalogName")%>
/div>
asp:PlaceHolder ID="PlaceHolderArticleList" runat="server">/asp:PlaceHolder>
/ItemTemplate>
/asp:DataList>

從數(shù)據(jù)庫(kù)獲取數(shù)據(jù)并綁定至目錄的DataList控件。
復(fù)制代碼 代碼如下:

View Code
Imports Insus.NET
Partial Class Index
Inherits System.Web.UI.Page
Dim objCatalog As New Catalog()
Dim objArticle As New Article()
Protected Sub Page_Load(sender As Object, e As EventArgs) Handles Me.Load
If Not IsPostBack Then
Data_Binding()
End If
End Sub
Private Sub Data_Binding()
objCatalog.IsActive = True
Me.DataListCatalog.DataSource = objCatalog.GetByIsActive()
Me.DataListCatalog.DataBind()
End Sub
End Class

下面是重點(diǎn),就是OnItemDataBound事件,在這個(gè)事件中,需要找到asp:PlaceHolder控件,這個(gè)容器將用來(lái)加載用戶控件。
復(fù)制代碼 代碼如下:

Protected Sub DataListCatalog_ItemDataBound(sender As Object, e As DataListItemEventArgs)
If e.Item.ItemType = ListItemType.Item OrElse e.Item.ItemType = ListItemType.AlternatingItem Then
'判斷asp:PlaceHolder是否存在
If e.Item.FindControl("PlaceHolderArticleList") IsNot Nothing Then
Dim ctllaceHolder As PlaceHolder = DirectCast(e.Item.FindControl("PlaceHolderArticleList"), PlaceHolder)
'動(dòng)態(tài)加載用戶控件,并轉(zhuǎn)換為接口。
Dim objuc As ISetValue = DirectCast(LoadControl("~/AscxControls/ArticleList.ascx"), ISetValue)
'找到DataList控件的目錄主鍵
objArticle.Catalog_nbr = Me.DataListCatalog.DataKeys(e.Item.ItemIndex)
objArticle.Top = 2
'為用戶控件賦值。
objuc.SetValue(objArticle.GetArticalTopByCatalog())
'加載用戶控件。
ctllaceHolder.Controls.Add(objuc)
End If
End If
End Sub
您可能感興趣的文章:
  • 獲取DataList控件的主鍵和索引實(shí)用圖解
  • 通過RadioButton對(duì)DataList控件進(jìn)行單選實(shí)例說明
  • Datalist控件使用存儲(chǔ)過程來(lái)分頁(yè)實(shí)現(xiàn)代碼
  • asp.net datalist 用法
  • DataList中TextBox onfocus調(diào)用后臺(tái)void靜態(tài)方法及獲取相應(yīng)行數(shù)

標(biāo)簽:臺(tái)州 嘉興 揚(yáng)州 南昌 海南 南京 淄博 南京

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《動(dòng)態(tài)加載用戶控件至DataList并為用戶控件賦值實(shí)例演示》,本文關(guān)鍵詞  動(dòng)態(tài),加載,用戶,控件,至,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《動(dòng)態(tài)加載用戶控件至DataList并為用戶控件賦值實(shí)例演示》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于動(dòng)態(tài)加載用戶控件至DataList并為用戶控件賦值實(shí)例演示的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 社会| 静海县| 冷水江市| 湖南省| 景德镇市| 桐柏县| 乌苏市| 卓尼县| 宜宾市| 祁连县| 南雄市| 嘉鱼县| 茂名市| 兰考县| 东光县| 永川市| 衡东县| 剑川县| 五华县| 江安县| 得荣县| 怀集县| 会宁县| 巨野县| 桃园市| 云南省| 巴彦淖尔市| 裕民县| 全州县| 民县| 锦屏县| 潜山县| 琼结县| 宝兴县| 平陆县| 阳东县| 玛纳斯县| 阜城县| 石河子市| 化德县| 馆陶县|