在asp.net(c#)中如何使用datalist控件

本人是菜鸟,不会使用datalist,对了,我不是想从vs工具栏里设置datalist,我是想在.cs代码文件里设置的.请高手帮忙.只要能够在页面中显示,并分页(1234... 本人是菜鸟,不会使用datalist,对了,我不是想从vs工具栏里设置datalist,我是想在.cs代码文件里设置的.请高手帮忙.
只要能够在页面中显示,并分页(1 2 3 4 5 6 )这样的分页就行了.
表名:product_info
字段:ID,productName,productPic(ID,产品名称,产品图片)
我不懂,下面是我乱写的.请高手帮忙,列出代码,重赏!!!

前台代码:<form id="form1" runat="server">
<div>
<asp:DataList ID="dl" runat="server" CellPadding="4" ForeColor="#333333">
<itemtemplate>
<%# DataBinder.Eval(Container.DataItem, "proname")%>
</itemtemplate>
</asp:DataList></div>

后台代码:

DataList dl = new DataList();

SqlCommand cmd = new SqlCommand("select * from product_info", conn);

SqlDataReader ds = cmd.ExecuteReader();
dl.DataSource = ds;

dl.DataBind();
conn.Close();

</form>
展开
 我来答
百度网友68bb5ad
2008-07-06 · TA获得超过172个赞
知道答主
回答量:80
采纳率:0%
帮助的人:0
展开全部
Asp.net提供了三个功能强大的列表控件:DataGrid、DataList和Repeater控件,但其中只有DataGrid控件提供分页功能。相对DataGrid,DataList和Repeater控件具有更高的样式自定义性,所以很多时候我们喜欢使用DataList或Repeater控件来显示数据。

实现DataList或Repeater控件的分页显示有几种方法:
1、写一个方法或存储过程,根据传入的页数返回需要显示的数据表(DataTable)
2、使用PagedDataSource类(位于System.Web.UI.WebControls命名空间里)

本篇文章主要说怎么使用PagedDataSource类实现DataList和Repeater控件的分页显示。DataGrid控件内部也使用了PagedDataSource类,PagedDataSource 类封装 DataGrid 控件的属性,这些属性使 DataGrid 可以执行分页。

PagedDataSource 类的部分公共属性:
AllowCustomPaging 获取或设置指示是否启用自定义分页的值。
AllowPaging 获取或设置指示是否启用分页的值。
Count 获取要从数据源使用的项数。
CurrentPageIndex 获取或设置当前页的索引。
DataSource 获取或设置数据源。
DataSourceCount 获取数据源中的项数。
FirstIndexInPage 获取页中的第一个索引。
IsCustomPagingEnabled 获取一个值,该值指示是否启用自定义分页。
IsFirstPage 获取一个值,该值指示当前页是否是首页。
IsLastPage 获取一个值,该值指示当前页是否是最后一页。
IsPagingEnabled 获取一个值,该值指示是否启用分页。
IsReadOnly 获取一个值,该值指示数据源是否是只读的。
IsSynchronized 获取一个值,该值指示是否同步对数据源的访问(线程安全)。
PageCount 获取显示数据源中的所有项所需要的总页数。
PageSize 获取或设置要在单页上显示的项数。
VirtualCount 获取或设置在使用自定义分页时数据源中的实际项数。

这些属性是否和DataGrid的属性很相似?没错,DataGrid控件就是使用PagedDataSource类来实现数据分页显示的 。下面举个使用PagedDataSource类实现DataList和Repeater控件的分页显示的例子:

public void Page_Load(Object src,EventArgs e)
{
OleDbConnection objConn=new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=c:\test.mdb");
OleDbDataAdapter objCommand=new OleDbDataAdapter("select * from Users",objConn);
DataSet ds=new DataSet();
objCommand.Fill(ds);

//对PagedDataSource 对象的相关属性赋值
PagedDataSource objPds = new PagedDataSource();
objPds.DataSource = ds.Tables[0].DefaultView;
objPds.AllowPaging = true;
objPds.PageSize = 5;
int CurPage;

//当前页面从Page查询参数获取
if (Request.QueryString["Page"] != null)
CurPage=Convert.ToInt32(Request.QueryString["Page"]);
else
CurPage=1;

objPds.CurrentPageIndex = CurPage-1;
lblCurrentPage.Text = "Page: " + CurPage.ToString();

if (!objPds.IsFirstPage)
lnkPrev.NavigateUrl=Request.CurrentExecutionFilePath + "?Page=" + Convert.ToString(CurPage-1);

if (!objPds.IsLastPage)
lnkNext.NavigateUrl=Request.CurrentExecutionFilePath+ "?Page=" + Convert.ToString(CurPage+1);

//把PagedDataSource 对象赋给Repeater控件
Repeater1.DataSource=objPds;
Repeater1.DataBind();
}

参考资料: http://zhidao.baidu.com/question/1514841.html

qianko
2008-07-06 · TA获得超过247个赞
知道小有建树答主
回答量:326
采纳率:0%
帮助的人:244万
展开全部
datalist控件本身不能进行分页,
一般是通过转页码号给页面
通过页面*每页行数
然后用这个值进行数据库查询
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友5043c0a
2008-07-06 · TA获得超过122个赞
知道小有建树答主
回答量:194
采纳率:0%
帮助的人:0
展开全部
DATALIST本身没有分页程序,需要自己写,GRIDVIEW有分页
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
darko2o8
2008-07-06 · TA获得超过616个赞
知道小有建树答主
回答量:987
采纳率:0%
帮助的人:441万
展开全部
2005可以
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式