DataList


         今天几天一下午的时候都在弄这个东西,所以觉得很有必要总结一下,dataList也是第一次用,以前用repeater的时候比较多。下面就通过几个小例子来展开吧,也是对自己学习的一个回顾。

基本内容介绍:

datalist中的模板:

DataList_第1张图片

datalist中的四个常用事件:

一、利用sqldatasource作为数据源,让它呈现数据。(这种方法不需要写一个代码就可以实现。)

1、在界面上放置一个datalist控件和一个sqldatasource,实验所用的数据库为pubs数据库中的authors表。

2、可以自动套用格式,让其更加美观。

DataList_第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();
            }
        }

    }
}

效果如图所示:

DataList_第3张图片


、实现分页效果

界面设计如图:

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后又变成原来的了。所以,做事一定要细心一些才行啊!

你可能感兴趣的:(String,object,query,Class,dataset,Hyperlink)