设计模版: 
页眉<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. python实现测试报告的bug统计

    背景:组内要针对每个项目生成测试报告,要对当前项目的一些bug进行统计.考虑到人工统计比较繁琐,而且是个长期的工作,所以写个脚本对bug进行自动统计.(我们用的bug平台是bugfree,直接可以导出 ...

  2. 2015年传智播客JavaEE 第168期就业班视频教程03-ERP简介(2)

    资源管理这块的东西大家基本上能够猜个差不多了.下面描述描述计划.计划这个东西把企业资源这个东西提升了不只十倍二十倍了.ERP的核心是计划,但是这次我们做是不做计划的.今年我们是一个生产型企业,我们要开 ...

  3. C 文件操作库函数总结

    目录: 1. fopen(打开文件)2. fprintf3. fscanf4. clearerr(清除文件流的错误旗标)5. fclose(关闭文件)6. fdopen(将文件描述词转为文件指针)7. ...

  4. 【BZOJ2806】Cheat 【广义后缀自动机+单调队列优化dp+二分】

    题意 有M篇标准作文组成了一个作文库(每篇作文都是一个01的字符串),然后给出N篇作文(自然也是01字符串).如果一个长度不小于L的串在作文库中出现过,那么它是熟悉的.对于某一篇作文,我们要把它分为若 ...

  5. Memcached在Linux环境下的使用详解http://blog.51cto.com/soysauce93/1737161

    大纲 一.什么是memcached 二.memcached特性 三.memcached存储方式 四.memcached安装与配置 五.memcached结合php 六.Nginx整合memcached ...

  6. [leetcode]301. Remove Invalid Parentheses 去除无效括号

    Remove the minimum number of invalid parentheses in order to make the input string valid. Return all ...

  7. [Selenium]重写拖拽dragWidgetToElementContainner()

    public void dragWidgetToElementContainner(String widgetName, String targetPosition){ WebElement widg ...

  8. 文字如何实现完美UI?文本排版设计告诉你

    一部手机,电量充足,网络通畅,就足以让我们打发一天的时光,尽情沉浸在手机时代的缤纷世界里.这个信息资源无穷尽的手机网络世界,是设计师和开发者们在不停的探索中一路一步精心打造.如何进一步美化这个世界,优 ...

  9. RECONSUME_LATER

    Failure consumption,later try to consume. ================MessageExt [queueId=0, storeSize=134, queu ...

  10. java并发编程实战:第十二章---并发程序的测试

    并发程序中潜在错误的发生并不具有确定性,而是随机的. 安全性测试:通常会采用测试不变性条件的形式,即判断某个类的行为是否与其规范保持一致 活跃性测试:进展测试和无进展测试两方面,这些都是很难量化的(性 ...