今天几天一下午的时候都在弄这个东西,所以觉得很有必要总结一下,dataList也是第一次用,以前用repeater的时候比较多。下面就通过几个小例子来展开吧,也是对自己学习的一个回顾。
基本内容介绍:
datalist中的模板:
datalist中的四个常用事件:
一、利用sqldatasource作为数据源,让它呈现数据。(这种方法不需要写一个代码就可以实现。)
1、在界面上放置一个datalist控件和一个sqldatasource,实验所用的数据库为pubs数据库中的authors表。
2、可以自动套用格式,让其更加美观。
二、实现自制数据源绑定
界面设计:
代码:
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; namespace DataList { public partial class _2 : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { db sdb = new db(); DataList1.DataSource = sdb.dt("select Top 10 * from authors"); DataList1.DataBind(); } } } }
db类代码:(后面的例子也会用到其中的方法。)
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Configuration; using System.Data; using System.Data.SqlClient; using System.Web.UI.WebControls; namespace DataList { public class db { protected string connstring; private int pagesize; public db() { connstring = ConfigurationManager.ConnectionStrings["pubsConnectionString"].ConnectionString; pagesize = 4; } /// <summary> /// 根据传入的SQL语句返回一个表 /// </summary> /// <param name="query"></param> /// <returns></returns> public DataTable dt(string query) { SqlConnection con = new SqlConnection(connstring); SqlDataAdapter sda = new SqlDataAdapter(query, con); DataSet ds = new DataSet(); sda.Fill(ds, "name"); return ds.Tables["name"]; } /// <summary> /// 返回一个可分页的数据源(分布大小为4),但是未定义当前页码 /// </summary> /// <returns></returns> public PagedDataSource pds() { PagedDataSource pds = new PagedDataSource(); pds.DataSource = dt("select * from authors").DefaultView; pds.AllowPaging = true; pds.PageSize = pagesize; pds.CurrentPageIndex = pds.CurrentPageIndex; return pds; } /// <summary> /// 根据查询语句返回一个表示该SQL语句受影响行数的整数。 /// </summary> /// <param name="query"></param> /// <returns></returns> public int sql(string query) { SqlConnection conn = new SqlConnection(connstring); conn.Open(); SqlCommand cmd = new SqlCommand(query, conn); //conn.Close(); //现在加这句话,会报错哦!!!!!!! return cmd.ExecuteNonQuery(); } /// <summary> /// 根据传进来的一个整数做为当前的页码并返回分布后的数据源。 /// </summary> /// <param name="pg"></param> /// <returns></returns> public PagedDataSource pds(int pg) { PagedDataSource pds = new PagedDataSource(); pds.DataSource = dt("select * from authors").DefaultView; pds.AllowPaging = true; pds.PageSize = pagesize; pds.CurrentPageIndex = pg; return pds; } } }
三、实现自制数据源的绑定与删除。
注意:在itemTemplate中 加入两个linkButton,一个是修改(commandName为“update”),一个是删除(commandName为“delete”)。 在editItemTemplate中两个linkButton,一个是保存(commandName为“update”),一个是取消(commandName为“cancel”)。
代码:
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; namespace DataList { public partial class _3 : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { bind(); } } private void bind() { db sdb = new db(); DataList1.DataSource = sdb.dt("select top 10 * from authors"); DataList1.DataKeyField = "au_id"; DataList1.DataBind(); } protected void DataList1_CancelCommand(object source, DataListCommandEventArgs e) { DataList1.EditItemIndex = -1; bind(); } protected void DataList1_EditCommand(object source, DataListCommandEventArgs e) { DataList1.EditItemIndex = e.Item.ItemIndex; bind(); } protected void DataList1_DeleteCommand(object source, DataListCommandEventArgs e) { string id = DataList1.DataKeys[e.Item.ItemIndex].ToString(); string query = "delete from authors where au_id='" + id+"'"; db sdb = new db(); if (sdb.sql(query)>0) { Response.Write("<scrip>return alert '删除成功!'"); DataList1.EditItemIndex=-1; bind(); } } protected void DataList1_UpdateCommand(object source, DataListCommandEventArgs e) { string id = DataList1.DataKeys[e.Item.ItemIndex].ToString(); string fname = ((TextBox)e.Item.FindControl("txtFname")).Text; string query = "update authors set au_fname='" + fname + "' where au_id='" + id+"'"; db sdb = new db(); if (sdb.sql(query)>0) { DataList1.EditItemIndex = -1; bind(); } } } }
效果如图所示:
四、实现分页效果
界面设计如图:
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; namespace DataList { public partial class _4 : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { int n; if (Request.QueryString["page"]!=null) { n = Convert.ToInt32(Request.QueryString["page"]); } else { n = 0; } bind(n); } } private void bind(int n) { db sdb = new db(); DataList1.DataSource = sdb.pds(n); DataList1.DataBind(); } protected void DataList1_ItemDataBound(object sender, DataListItemEventArgs e) { if (e.Item.ItemType== ListItemType.Footer) { PlaceHolder ph = (PlaceHolder)e.Item.FindControl("ph"); db sdb = new db(); for (int i = 0; i < sdb.pds().Count; i++) { HyperLink hl = new HyperLink(); Literal nsb = new Literal(); int n = i + 1; hl.Text = n.ToString(); hl.ID = n.ToString(); hl.NavigateUrl = "?page=" + i.ToString(); nsb.Text = " "; ph.Controls.Add(hl); ph.Controls.Add(nsb); } } } } }
到此就基本介绍完毕了。
自己在做的过程中犯了一个小错误,耽误了自己不少的时候,就是在做第三个演示的时候,没有判断是否回发,造成自己修改au_fname后又变成原来的了。所以,做事一定要细心一些才行啊!