设计模版: 
页眉<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. 微信小程序通讯录首字母索引效果,车辆品牌选择列表

    效果图: wxml代码: <block wx:for="{{list}}"> <view class='letter' id="letter{{inde ...

  2. Spring Boot 简单入门

    添加相关依赖 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http ...

  3. linux下mysql开启远程访问权限及防火墙开放3306端口(mysql开放host访问权限)

    开启mysql的远程访问权限默认mysql的用户是没有远程访问的权限的,因此当程序跟数据库不在同一台服务器上时,我们需要开启mysql的远程访问权限.主流的有两种方法,改表法和授权法.相对而言,改表法 ...

  4. SQLServer锁的机制

    SQLServer锁的机制:共享锁(S)排它锁(X)更新锁(U)意向共享 (IS)意向排它 (IX) 意向排它共享 (SIX)架构修改(Sch-M) 架构稳定性(Sch-S)大容量更新(BU)

  5. SLAM应用的一些思考

    关心SLAM技术的人有两种.一是像我这样的研究者,为了了解其中各种方法和模块的原理.二是机器人技术的开发者,旨在将SLAM技术用到他们自己的机器人上.从数量上来说,第二类人数远多于第一类,他们的需求也 ...

  6. Linux服务器上如何设置MySQL的max_allowed_packe

    mysql根据配置文件会限制server接受的数据包大小. 有时候大的插入和更新会被max_allowed_packet 参数限制掉,导致失败. 查看目前配置  show VARIABLES like ...

  7. net 程序员面试宝典

    第1部分 求职过程 ------------------------------------------------------------------------------------------ ...

  8. linux中的 tar命令的 -C 参数,以及其它一些参数

    tar命令的-C参数    $ tar -cvf file2.tar /home/usr2/file2 tar: Removing leading '/' from members names hom ...

  9. 使用js/jquery查找iframe中的

    原生js  一.在iframe的父窗口中获取iframe中的元素: js代码 格式: window.frames["iframe的name值"].document.getEleme ...

  10. Restful风格wcf调用2——增删改查

    写在前面 上篇文章介绍如何将wcf项目,修改成restful风格的接口,并在上面提供了查询的功能,上篇文章中也感谢园友在评论中的提的建议,自己也思考了下,确实是那个道理.在urltemplate中,定 ...