【问题标题】:How to create ASP.NET user/server control that uses a list of asp:ListItem as child controls?如何创建使用 asp:ListItem 列表作为子控件的 ASP.NET 用户/服务器控件?
【发布时间】:2010-10-22 02:59:18
【问题描述】:

我希望创建一个用户/服务器控件,该控件将使用以下内容创建:

<my:MyListControl runat="server">
   <asp:ListItem Text="Test1" Value="Test1" />
   <asp:ListItem Text="Test2" Value="Test2" />
</my:MyListControl>

我只是在这里寻找一个开始: 文章或代码示例。

我应该从哪个基类继承?要覆盖什么?

可能如何自定义我的控件接受的子项(my:ListItem 而不是 asp:ListItem)。

我要做的是为我网站的一小部分创建一个非常简单的面包屑控件。我已经将所有这些都与股票 ASP.NET 控件一起使用,但是这些项目是在代码中添加的,这意味着修复拼写错误或格式错误需要重新编译,这并不理想。

编辑:

这是我的代码,并在下面添加了 Josh 的建议:

命名空间 MySite.Controls 部分类面包屑 继承用户控件

    Private m_BreadCrumbs As New List(Of BreadCrumbItem)

    <PersistenceMode(PersistenceMode.InnerProperty)> _
    Public Property Items() As List(Of BreadCrumbItem)
        Get
            Return m_BreadCrumbs
        End Get
        Set(ByVal value As List(Of BreadCrumbItem))
            m_BreadCrumbs = value
        End Set
    End Property

    Private Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs) Handles MyBase.Load
        Bind()
    End Sub

    Private Sub Bind()
        lvCrumbs.DataSource = Items
        Me.DataBind()
    End Sub
End Class

Public Class BreadCrumbItem
    Private m_Text As String
    Public Property Text() As String
        Get
            Return m_Text
        End Get
        Set(ByVal value As String)
            m_Text = value
        End Set
    End Property

    Private m_Url As String
    Public Property Url() As String
        Get
            Return m_Url
        End Get
        Set(ByVal value As String)
            m_Url = value
        End Set
    End Property
End Class

结束命名空间

那么我的页面代码是这样的:

<%@ Page Language="VB" AutoEventWireup="false" Inherits="MySite.MyPage" Title="My Page" Codebehind="MyPage.aspx.vb" %>
<%@ Register TagPrefix="my" Namespace="MySite.Controls" Assembly="MySite" %>
<my:BreadCrumbs ID="breadcrumbs" runat="server">
    <Items>
        <my:BreadCrumbItem Text="Another page" Url="AnotherPage.aspx" />
    </Items>
</my:BreadCrumbs>

【问题讨论】:

  • 最终的 HTML 标记目标是什么?类似于:
    • Test1
    • Test2
    使用 ListItem 而不是其他类型有什么需要?
  • 是的,我吐出的 HTML 是 ul/li。不需要asp:ListItem,只是问的时候不知道还能叫什么

标签: .net asp.net user-controls servercontrols


【解决方案1】:

使用 asp:Repeater 然后将其绑定到您想要在面包屑中包含的对象列表。您可以使用模板自定义项目本身和分隔符。

【讨论】:

  • 我想要一些比中继器控件更明确的东西
【解决方案2】:

您可以在用户控件的代码后面添加一个属性,例如:

[PersistenceMode(PersistenceMode.InnerProperty)]
public List<ListItem> Items
{
    get;
    set;
}

您的标记将是:

<my:MyListControl runat="server">
  <Items>
    <asp:ListItem/>
  </Items>
</my:myListControl>

为了使 ListItem 可以成为您自己的列表项(我建议这样做,而不是使用 asp.net。)您需要创建自己的类。

这是我使用的服务器控件的示例(我删除了很多噪音,因此这只是一个骨架):

   [ToolboxData("<{0}:Menubar runat=server></{0}:Menubar>")]
    [System.ComponentModel.DesignTimeVisible(false)]
    public class Menubar : WebControl, IPostBackEventHandler
    {

        private List<MenuItem> _menuItems = new List<MenuItem>();
        [PersistenceMode(PersistenceMode.InnerProperty)]
        public List<MenuItem> MenuItems
        {
            get
            {
                return _menuItems;
            }
        }

    }
    [ToolboxItem(false)]
    [ParseChildren(true, "MenuItems")]
    public class MenuItem
    {
        private string _clientClick;
        private List<MenuItem> _menuItems = new List<MenuItem>();

        [Localizable(true)]
        public string Title { get; set; }
        public string Href { get; set; }
        public string Id { get; set; }
        [PersistenceMode(PersistenceMode.InnerDefaultProperty)]
        public List<MenuItem> MenuItems
        {
            get { return _menuItems; }
            set { _menuItems = value; }
        }
    }

现在我可以这样使用:

<my:Menubar runat="server" ID="menuBar">
    <MenuItems>
        <my:MenuItem Title="Save" Href="javascript:saveItem(this);"  />
        <my:MenuItem Title="Print" Href="javascript:void(0);">
            <MenuItems>
                <my:MenuItem Title="Preview" Href=""/>
                <my:MenuItem Title="To Pdf" Href="javascript:"/>
            </MenuItems>
        </my:MenuItem>
    </MenuItems>
</my:Menubar>

【讨论】:

  • 这似乎是我需要的。我现在唯一挂断的是为什么我的 @Register TagPrefix="my" Namespace="MySite.Controls" 无法获取自定义列表项类?有任何想法吗?它获取父控件(在您的示例中为菜单栏),但我无法在 Items 标记内执行 my:MyListItem。
  • 没关系。需要将 Assembly 参数添加到 @Register 指令。现在它起作用了。谢谢乔什
猜你喜欢
  • 2011-02-27
  • 2012-07-18
  • 2011-03-09
  • 2012-07-12
  • 2011-03-17
  • 2011-02-23
  • 2010-10-30
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多