3、事件
加入模版列的按钮会将其click事件反升到 ItemCommand 事件,也可设置 CommandName 来响应不同的事件,如设为:edit,即引发EditCommand()等。
在ASP.NET中有三个控件带有CommandName属性,分别是Button、LinkButton和ImageButton,可以设置它们的CommandName属性来表示容器控件内产生的时间类型。
1) EditCommand:由带有CommandName=”edit”的子控件产生
2) CancelCommand:由带有CommandName=”cancel”的子控件产生
3) UpdateCommand:由带有CommandName=”update”的子控件产生
4) DeleteCommand:由带有CommandName=”delete”的子控件产生
5) ItemCommand:DataList的默认事件
响应顺序为先响应ItemCommand ,并判断其中的CommandName分别响应,如果有EditCommand\EditCommand\UpdateCommand\DeleteCommand后响应
注:若设为: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 元素 datalist 元素 01 datalist 元素 datalist 元素 datalist元素用于定义输入框的选项列表,列表通过datalist内的option元素进行创建。如果用户不希望从列表中选择某项,也可以自行输入其他内容。 描述 ...
datalist 中嵌套datalist,纯文本格式,非常小·
刚学php ,模仿一asp.net 的datalist类似的功能 $temp; $db=new MyDB(); $sqlcommand='SELECT *, COUNT(DISTINCT dealerTitle) FROM indexshoplist GROUP BY dealerTitle LIMIT 12'; $TableId='...
一个DataList 嵌套DataList的例子,希望对各位有帮助。
datalist分页技术及实现,解决了许多,分页难以解决的问题,及更加灵活控制
本文给大家分享的是使用jQuery实现的房HTML5中的一个好看的input框很好看的下拉列表--datalist,兼容性非常不错,这里推荐给大家,有需要的小伙伴可以参考下。
利用DataList控件实现加入购物车,查看购物车,结账功能。
DataList中如何响应DropDownList的SelectedIndexChanged事件
本影片中Datalist包含DataList,大类别包含小类别以及程式重构.片长:0:43:48; 大小:17088KB
datalist控件的使用(—)里面有相关的应用实例
DataList 分页源码 DataList 分页源码 DataList 分页源码 DataList 分页源码
DataList控件与AspNetPager分页控件三层实现,数据库都有,很好学习使用。
参数传递形式是PagerPartsReview1.getData(datatable,一页显示多少条, 父datalist, 父datalist.datakeyfield, 子datalist,子datalist.datakeyfield);另有适合单datalist的分页控件。请大家下载。 初次做资源,希望有...
自己写的实现DataList分页功能,自认为比以往的分页功能效率提高了许多,因为以往都是把数据全部查询出来后再进行分页,并且,每点击下一页时,就重新查询所有数据一遍,当数据量特别大时,很耗费时间,并且,浪费...
很详细的DataList控件的视频讲解,共享出来了,保证对你有收获
使用datalist控件 实现 条件查询 并且 分页的一个列子 很简单 一看就懂 一学就会
在此把DataList的几个方法实现了一下,有浏览,更新,删除,编辑等功能!
datalist 嵌套,多个datalist 嵌套,vs2008+sql2005datalist 嵌套,多个datalist 嵌套,vs2008+sql2005
DATALIST显示数据库信息 DATALIST显示数据库信息 DATALIST显示数据库信息 DATALIST显示数据库信息
javascript控制更换datalist的背景图片,技巧性