设计模版: 
页眉<HeaderTemplate>   
</HeaderTemplate> 
页脚<FooterTemplate> 
</FooterTemplate>
数据记录<ItemTemplate> 
</ItemTemplate> 
<AlternatingItemTemplate>     交替显示项 
</AlternatingItemTemplate> 
<SelectedItemTemplate>选中时的显示方式    
</SelectedItemTemplate> 
<EditItemTemplate> 编辑时的显示方式 
</EditItemTemplate> 
<SeparatorTemplate>    数据记录分隔符 
</SeparatorTemplate> 
编辑模版,里面可以嵌入控件,绑定数据。 
<ItemTemplate> 
    <table> 
    <tr> 
     <td><%# DataBinder.Eval(Container.DataItem, "持股名称") %></td> 
     <td><%# DataBinder.Eval(Container.DataItem, "市值", "{0:n}") %></td> 
     <td><%# DataBinder.Eval(Container.DataItem, "净值", "{0:n}") %></td> 
    </tr> 
</table> 
</ItemTemplate> 
设置外观 
RepeatLayout          属性设置显示方式
RepeatDirection       显示方向
RepeatColumns        列数
事件

加入模版列的按钮会将其click事件反升到 ItemCommand 事件,也可设置 CommandName 
来响应不同的事件,如设为:edit,即引发EditCommand()等。 
注:若设为:select 则会引发SelectedIndexChanged 和ItemCommand事件
SelectedItemTemplate模版;    添加详细信息的控件,当用户选择了该项,选择模版则显示。 
private void DataList1_ItemCommand(……) 
{    switch(e.CommandName) 
      { 
     case "select": 
             this.DataList1.SelectedIndex=e.Item.ItemIndex; 
              string s=(string)this.DataList1.DataKeys[e.Item.ItemIndex]; 
              //在此获得该条记录的详细数据,在SelectedItemTemplate模版里显示。 
              break; 
      case "unselect": 
            this.DataList1.SelectedIndex=-1; 
       break; 
    } 
    this.DataList1.DataBind();//一定要 

EditItemTemplate模版 
    编辑: 
    this.DataList1.EditItemIndex=e.Item.ItemIndex; 
     this.DataList1.DataBind(); 
    更新: 
得到主键 
string s=(string)this.DataList1.DataKeys[e.Item.ItemIndex]; 
得到模版里的控件 
TextBox box=(TextBox)e.Item.FindControl("TextBox1"); 
更新记录 
this.DataList1.DataBind(); 
    取消: 
this.DataList1.EditItemIndex=-1; 
this.DataList1.DataBind(); 
删除项 
一次勾选多条记录,一次删除 
              foreach(DataListItem i in this.DataList1.Items) 
     {

bool IsChecked=((CheckBox)i.FindControl("deletectr")).Checked;

if(IsChecked) 
                  { 
                      string s=(string)this.DataList1.DataKeys[e.Item.ItemIndex];

删除操作        }


运行中自定义DataList控件 
//当创建DataList控件中的任意项时 
private void DataList1_ItemCreated(object sender, System.Web.UI.WebControls.DataListItemEventArgs e) 

switch(e.Item.ItemType) 
{    case ListItemType.Header: 
             e.Item.ForeColor=Color.Red; 
              e.Item.BackColor=Color.Black; 
              break; 
      case ListItemType.Item: 
              e.Item.BackColor=Color.Black; 
               break; 
    } 

//当模版中的项被数据绑定时发生,数据被显示到客户端前加以访问的最后机会 
private void DataList1_ItemDataBound(object sender, System.Web.UI.WebControls.DataListItemEventArgs e) 

if((e.Item.ItemType==ListItemType.Header)||(e.Item.ItemType==ListItemType.Item)) 
    { 
        System.Data.Common.DbDataRecord drv= 
           (System.Data.Common.DbDataRecord)e.Item.DataItem; 
            if((decimal)drv["库存量"]<1000) 
       { 
      e.Item.ForeColor=Color.Red; 
        } 
     }

}

另种方式
    if((e.Item.ItemType==ListItemType.Header)||(e.Item.ItemType==ListItemType.Item))


             DataRowView drv=(DataRowView)e.Item.DataItem; 
                 string department=(string)drv["部门"]; 
                  switch(department) 
                  {    case "销售部":

e.Item.BackColor=Color.Black;

break; 
               case "技术部": 
                        e.Item.BackColor=Color.Red; 
     break;    } 
    }

DataList用法总结的更多相关文章

  1. DataList 用法详解

    <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="DataList.aspx. ...

  2. html学习_html5 新增标签和属性

    html5 新增标签和属性 1.html发展历程(html有很多版本) 2.快捷键生成不同版本(html4.xhtml.html5) 文档类型不同.字符设定 3.常用新标签 (只有html5才识别的标 ...

  3. GridView控件 Reapter控件 DataList控件 的区别和用法

    ASP.NET三大控件: 1.GridView控件:表格视图控件,可以用来绑定结果集或者视图,用起来比较方便和灵活,三个控件中使用最多的控件 用法--- this.gridview1.DataSour ...

  4. datalist的用法

    DataList 提供相关的编辑模板,但和DataGrid不一样的是,DataList没有编辑按钮.要在DataList中使用编辑功能,可在项模板中增加一个按 钮,Linkbutton和Button都 ...

  5. ElasticSearch的基本用法与集群搭建

    一.简介 ElasticSearch和Solr都是基于Lucene的搜索引擎,不过ElasticSearch天生支持分布式,而Solr是4.0版本后的SolrCloud才是分布式版本,Solr的分布式 ...

  6. 2016年第2周读书笔记与工作笔记 scrollIntoView()与datalist元素

    这一周主要是看了html5网页开发实例与javascript 高级程序设计,供以后翻阅查找.  html5网页开发实例第1章与第二章的2.1部分: 第1章内容: html5在w3c的发展史. 浏览器的 ...

  7. H5 新标签用法及解释

    HTML 5 是一个新的网络标准,目标在于取代现有的 HTML 4.01, XHTML 1.0 and DOM Level 2 HTML 标准.它希望能够减少浏览器对于需要插件的丰富性网络应用服务(p ...

  8. sp.net2.0中的新增控件BulletedList的一些高级用法

    asp.net2.0新增了一个BulletedList控件,通过它可以以列表形式显示数据,而不必再用Repeater,Datalist等实现相同的效果.今天做程序的时候正好用到了这个控件,就把它的一些 ...

  9. Html5新标签解释及用法

    Html5新标签解释及用法 HTML 5 是一个新的网络标准,目标在于取代现有的 HTML 4.01, XHTML 1.0 and DOM Level 2 HTML 标准.它希望能够减少浏览器对于需要 ...

随机推荐

  1. json的例子

    {  "Code": 200,  "Msg": "",  "Result": "{\"Platfor ...

  2. 29. Divide Two Integers (INT; Overflow, Bit)

    Divide two integers without using multiplication, division and mod operator. If it is overflow, retu ...

  3. leetcode 204 count prim 数素数

    描述: 给个整数n,计算小于n的素数个数. 思路: 埃拉托斯特尼筛法,其实就是普通筛子,当检测到2是素数,去除所有2的倍数:当检测到3是素数,去除其倍数. 不过这要求空间复杂度为n,时间复杂度为n. ...

  4. 自定义对象实现copy,遵守协议<NSCopying, NSMutableCopying>

    自定义对象实现copy,步骤 1.需要遵守NSCopying协议 2.实现协议中的- (id)copyWithZone:(NSZone *)zone 3.在- (id)copyWithZone:(NS ...

  5. 安装scrapy解决的坑

    在windows下: pip install scrapy 最后一步报错: 本来以为是缺少 Microsoft Visual C++ 14.0 这个库,一看下载需要400多M,算了再看下报错... 感 ...

  6. php识别二维码

    php-zbarcode 是 PHP 读取条形码的扩展模块,目前仅支持 php5.x

  7. jvm编译环境搭建 win Vc篇

    /************************************************************** 技术博客 http://www.cnblogs.com/itdef/   ...

  8. Java程序设计17——多线程-Part-B

    5 改变线程优先级 每个线程执行都具有一定的优先级,优先级高的线程获得较多的执行机会,而优先级低的线程则获得较少的执行机会. 每个线程默认的优先级都与创建它的父线程具有相同的优先级,在默认情况下,ma ...

  9. guestfish修改镜像内容

    1.安装guestfish yum install libguestfs-tools 注意,如果要修改windows镜像需要安装 yum install libguestfs-winsupport 2 ...

  10. CLOB 和 BLOB

    An SQL CLOB is a built-in type that stores a Character Large Object as a column value in a row of a ...