zoukankan      html  css  js  c++  java
  • 如何:在 DataList Web 服务器控件中动态创建模板

    如何:在 DataList Web 服务器控件中动态创建模板 

    模板不必在设计时进行分配。在某些情况下,可能能够在设计时布局模板,但是知道在运行时所做的更改非常广泛,以至于在运行时加载新的模板反而可简化编程。在其他情况下,可能有几个可能的模板,但要在运行时更改模板。

    创建模板定义文件

    1. 创建一个新的文本文件,使用 .ascx 扩展名。

    2. 向该模板文件添加模板定义语句并保存该文件(使用的标记应与所有声明性模板中使用的相同)。

      下面的示例显示一个具有模板标记的 .ascx 文件的内容,该模板包含数据绑定 Label 控件。数据绑定将在运行时根据绑定到 DataList 控件的数据源进行解析。

      Name: <asp:Label ID="CategoryNameLabel" runat="server" 
      Text='<%# Eval("CategoryName") %>'>
      </asp:Label>
      <br />
      Description: <asp:Label ID="DescriptionLabel" runat="server"
      Text='<%# Eval("Description") %>'>
      </asp:Label>

    动态创建模板

    • 向 Web 窗体页中添加代码以使用 LoadTemplate 方法加载模板。此方法从文件中读取模板定义,并创建一个 ITemplate 对象。然后可将此对象分配到 DataList 控件中的任何模板。

      下面的代码使用 Page_Load 事件处理程序来加载按上述过程创建的名为 NewTemplate.ascx 的模板。

      Visual Basic
      Protected Sub Page_Init(ByVal Sender As System.Object, _
      ByVal e As System.EventArgs)
      If (Not Page.IsPostBack) Then
      DataList1.AlternatingItemTemplate = _
      Page.LoadTemplate("NewTemplate.ascx")
      End If
      End Sub

      C#
      protected void Page_Init(object sender, EventArgs e)
      {
      DataList1.AlternatingItemTemplate =
      Page.LoadTemplate("NewTemplate.ascx");
      }

    请参见

    参考

    DataList Web 服务器控件概述
  • 相关阅读:
    NLP---word2vec的python实现
    matplotlib---Annotation标注
    matplotlib---legend图例
    matplotlib---设置坐标轴
    windows下右键新建md文件
    vue+webpack+npm 环境内存溢出解决办法
    element-ui tree树形组件自定义实现可展开选择表格
    vue-动态验证码
    ES6 数组函数forEach()、map()、filter()、find()、every()、some()、reduce()
    eslint配置文件规则
  • 原文地址:https://www.cnblogs.com/xiaotaoliang/p/618219.html
Copyright © 2011-2022 走看看