各种数据绑定控件间的区别

 

控件 主要数据结构 功能 描述和主要用途
GridView 读取编辑 每个字段一列
每个字段值对应于自已的一个单元格
在网络中显示多条记录
编辑现有记录
DataList 表或树 读取和编辑 所有字段在一个单元格中
一个单元格等于一条记录
在网格中显示多条记录
在GridView创建新记录
Repeater 表或树 只读 所有字段在一个单元格中
一个单元格等于一条记录
在网格中显示多条记录.为GridView创建新记录
DetailView 表或树 读取编辑、创建 显示单个记录
提供默认结构
编辑现有记录
创建新记录
FormView 表或树 读取编辑、创建 显示单个记录
没有默认结构
编辑现有记录
创建新记录
DropDownList和ListBox 表或树 只读 列出字段
让用户选择
显示供用户选择的数据
SiteMapPath 只读 列出主页和当前页面之间的页面名称
用于确定当前所处的站点位置
Menu 只读 显示根节点,能够选择一次展开一个子节点
用于显示选择的菜单
TreeView 只读 显示根节点,能够选择一次展开一个子节点
用于同时显示多个子节点

数据绑定控件比较(Reapter\DataList\GridView\DatailsView\FormView):
1.插入功能方面:
DetailsView和FormView具有插入功能,其它控件没有
2.模板
DataList\FormView\Repeater三种必须编辑模板,而
GridView和DetailsView只有在将列转换成模板列以后才会出现各种模板.
3.自动分页功能
GridView ,DetailsView和FormView都是2.0版本新增控件,内置了分页,排序等等功能,
其他需要手工定义
4.数据呈现方式:
GridView,DataList,Repeator用于呈现多列数据,
DetailsView,FormView用于呈现单列数据,即常用的数据明细.


DataList和Reapter都需要编辑模板列,而在模板列当中可以添加TextBox,同时可以指定TextBox的ID从而实现提取用户输入的值,但是DataGrid和GridView两个件是不需要编辑模板的,它的编辑功能是自动生成的我们无法知道那些文本框的ID,也就无法通过ID来获取用户的输入,那么可以通过对单元格的引用来实现:
private void DataGrid1_UpdateCommand(object source,xx)
{
    string bkid=DataGrid1.DataKeys[e.Item.ItemIndex].toString();//提取主键
    string bktitle=((TextBox)e.Item.Cells[1].Controls[0]).Text;//提取用户的输入
}

 

一.进入编辑状态:
DataList1.EditItemIndex = e.Item.ItemIndex;
DataGrid1.EditItemIndex = e.Item.ItemIndex;
GridView1.EditIndex = e.NewEditIndex;
DetailsView1.ChangeMode(DetailsViewMode.Edit);//进入编辑状态
DetailsView1.ChangeMode(DetailsViewMode.ReadOnly);//退出编辑状态


二.设置主键:
DataList1.DataKeyField = "bkid";
DataGrid1.DataKeyField = "bkid";

string[] str={"bkid"};
GridView1.DataKeyNames = str;


三.提取主键:
string bkid = DataList1.DataKeys[e.Item.ItemIndex].ToString();//DataList
string bkid = DataGrid1.DataKeys[e.Item.ItemIndex].ToString();//DataGrid
string bkid = GridView1.DataKeys[e.RowIndex].Value.ToString();//GridView
string bkid = DetailsView1.DataKey[0].ToString();

四.查找控件:
string bktitle = ((TextBox)e.Item.FindControl("txtTile")).Text;//DataList
string bktitle = ((TextBox)e.Item.Cells[1].Controls[0]).Text;//DataGrid
string bktitle = ((TextBox)GridView1.Rows[e.RowIndex].Cells[1].Controls[0]).Text;
string bktitle = ((TextBox)DetailsView1.Rows[1].Cells[1].Controls[0]).Text;


注意查找控件有两种方法:(各数据绑定控件的都可以用下面两种方法进行查找)
1.如果知道控件的ID可以用这种方法
((TextBox)e.Item.FindControl("txtTile")).Text;//这是查找
2.如果不知道控件的ID可用这种方法
((TextBox)e.Item.Cells[1].Controls[0]).Text;//这是索引


五.给删除按钮添加确认:
protected void DataList1_ItemDataBound(object sender, DataListItemEventArgs e)
     {
         if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
         {
             LinkButton lbtn =(LinkButton) e.Item.FindControl("lbtndelete");
             lbtn.Attributes.Add("OnClick","return confirm(‘确定要删除吗?‘)");
         }
     }

protected void DataGrid1_ItemDataBound(object sender, DataGridItemEventArgs e)
     {
         if(e.Item.ItemType==ListItemType.Item || e.Item.ItemType==ListItemType.AlternatingItem)
         {
             LinkButton lbtn = (LinkButton)e.Item.Cells[3].Controls[0];
             lbtn.Attributes.Add("OnClick","return confirm(‘确认删除?‘)");
         }
     }


protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
     {
         if(e.Row.RowType== DataControlRowType.DataRow)
         {
             string strid = e.Row.Cells[0].Text;//获取第一行的字段值;
             e.Row.Cells[3].Attributes.Add("OnClick", "return confirm(‘确认删除\""+strid+"\"?‘)");
             //用了两个转义符将第一列的值用引号括起来,注意转义符后面一个将不被解释,是直接放上去;

         }
     }

posted on 2008-11-01 08:37  子非魚  阅读(287)  评论(0编辑  收藏  举报