今天几天一下午的时候都在弄这个东西,所以觉得很有必要总结一下,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后又变成原来的了。所以,做事一定要细心一些才行啊!