今天几天一下午的时候都在弄这个东西,所以觉得很有必要总结一下,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后又变成原来的了。所以,做事一定要细心一些才行啊!
分享到:
相关推荐
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分页控件三层实现,数据库都有,很好学习使用。
自己写的实现DataList分页功能,自认为比以往的分页功能效率提高了许多,因为以往都是把数据全部查询出来后再进行分页,并且,每点击下一页时,就重新查询所有数据一遍,当数据量特别大时,很耗费时间,并且,浪费...
参数传递形式是PagerPartsReview1.getData(datatable,一页显示多少条, 父datalist, 父datalist.datakeyfield, 子datalist,子datalist.datakeyfield);另有适合单datalist的分页控件。请大家下载。 初次做资源,希望有...
很详细的DataList控件的视频讲解,共享出来了,保证对你有收获
使用datalist控件 实现 条件查询 并且 分页的一个列子 很简单 一看就懂 一学就会
在此把DataList的几个方法实现了一下,有浏览,更新,删除,编辑等功能!
datalist 嵌套,多个datalist 嵌套,vs2008+sql2005datalist 嵌套,多个datalist 嵌套,vs2008+sql2005
DATALIST显示数据库信息 DATALIST显示数据库信息 DATALIST显示数据库信息 DATALIST显示数据库信息
javascript控制更换datalist的背景图片,技巧性