repeater 控件ajax绑定数据源,【ASP.NET】第九课——使用DataList控件和Repeater控件绑定数据...

知识点:掌握 DataList 控件呈现数据的方法; 掌握 Repeater 控件呈现数据的方法;掌握处理 Repeater 控件中的按钮事件。

1、 使用 DataList 控件呈现数据

在用 ASP.NET 开发 Web 应用程序时,DataList 是非常重要的数据绑定控件。DataList 控件 可用于创建模板化的列表数据,如果重复结构比较复杂,那么建议使用 DataList 和 Repeater 控件,因为 GridView 控件比较适合显示多行多列的表格类数据。

示例练习1:DataList控件的使用

要求:制作一个车型展示页面,使用DataList控件。

前提:在【ASP.NET第八课】的基础之上完成。

第一步,添加Web窗体:在VS中打开已有项目【WebApplication7】,右键单击项目名称【WebApplication7】,依次点击【添加】→【Web窗体】,将窗体命名为CarList,然后单击【确定】。

9dd18240c216297b71b127e9be06a752.png

第二步,添加DataList控件:在默认打开的CarList.aspx文件中,从工具箱拖放一个DataList控件到适合的位置。

e4c9716fee245f040494dd4509097d53.png

第三步,绑定数据源:打开CarList.aspx文件,切换到【拆分】视图。

①选中DataList控件后,点击右上角

ebbcaa10d9adad411127b31a08ba6506.png,在弹出的【DataList任务】中,点击【选择数据源】,然后点击下拉箭头,点击【】

c3cf96049cc223215c8f2a45309920f5.png

②在弹出的【数据源配制向导】窗体中,选择默认应用程序从哪里获取数据?【数据库】,为数据源指定ID,使用默认名称,然后点击【确定】

646138845c93446c4e932c1aabbbf8ea.png

③在弹出的【配制数据源】窗口中,点击【新建连接】按钮

41f622dbb897818772c0ee75d2194624.png

④在弹出的【添加连接】窗口中,输入服务器名,这个一般可以使用英文的点即可。如果无法使用英文点,则需要写数据库按照时的服务器名。然后再下面点选要连接的数据库名称,最后点击【确定】

fb622a7c7c63c4856da2784475042bd8.png

⑤此时会自动填写一行代码,直接点击【下一步】

836fcb614070d1b5f543f7f04c008171.png

⑥单击【下一步】

5fcb858eb0121c0e5d70aa8ea996582e.png

⑦在【配置数据源】窗口中,设置想要查询的数据,我们这查询Scar表的所有列,然后点击【下一步】

91c91a9158fe1d400fdc75be77246dcb.png

⑧可以点击【测试查询】看一下结果,最后点击【完成】按钮。

a2c654414a3a91ae152dfe870a97d767.png

⑨注意分析查看此时源代码文件

7b64e57a89717cb809fada2b120993b1.png

代码分析:DataList 的模板类型包括:ItemTemplate 用于显示项,AlternatingItemTemplate 用于显 示交替项,EditItemTemplate 用于显示编辑项,同时也支持 HeaderTemplate、FooterTemplate 等模板,这些模板的作用与 GridView 控件中模板列的模板相同。另外,DataList 还支持间隔项 模板 SeparatorTemplate,用于在两个项之间显示。

DataList—王迪

CarId:

CarName:

BrandId:

Picture:

OfficialPrice:

Click:

第四步,运行测试:在CarList.aspx页面单击鼠标右键,然后点击【在浏览器中查看】

f14be799221877fa5eea75b620329c97.png

我们看到数据源中的所有数据显示出来,但是一行只显示一列数据。

观察一下页面源代码:DataList控件默认输出是一个table表格。

第五步,设置列数:给DataList控件添加一个RepeatColumns属性。

32813243f0fc95ce4fa6a43ac965ff8b.png

a29c61e815f1671e534cc2b4bbc2110f.png

第六步,设计样式:

①先制作一个样式出来,写div+css实现图中效果。

8e7be098bf6ad5042c69ccfd360252fb.png

DataList—王迪

汽车名称

ada31.jpg

编号:

官方价格:

点击量:

CarId:

CarName:

BrandId:

Picture:

OfficialPrice:

Click:

②将写好的样式,套用到DataList控件中。

d4d9c75058525dc5661c1e30e5330de0.png

DataList—王迪

<%#%20Eval(" />

编号:

官方价格:

点击量:

运行测试:

9efd099e2d1a7b30ae1863e0b97d866b.png

细节调整:如每个产品之间增加一些间隔,可以设置div的margin属性,如margin:0px 10px 20px 0px;

2、Repeater 控件

Repeater 控件专门用于精确内容的显示,它也是基于模板的方式,不过它不会自动生成任 何用于布局的代码。Repeater 控件甚至没有一个默认的外观,它完全是通过模板来控制。而且也只能通过源代码视图进行模板的编辑。

2.1  使用 Repeater 控件呈现数据

GridView 和 DataList 自动生成标签,但是 Repeater 控件不会自动生成任何 HTML 标签,所以带来了效率上的提升,也使精确展示内容成为可能。

示例练习2:使用 Repeater 控件呈现数据

要求:在当前项目中,新添加一个Web窗体,并使用 Repeater 控件呈现车型列数据。

第一步,添加Web窗体:右键单击项目名称【WebApplication7】,依次点击【添加】→【Web窗体】,将窗体命名为CarListRepeater,然后单击【确定】。

e7df65dba4d271d8dfc3bf2d33574f06.png

第二步,添加Repeater控件:在默认打开的CarListRepeater.aspx文件中,从工具箱拖放一个Repeater控件到适合的位置。

ff99ade045cf4f5038c71f4d77d33368.png

第三步,绑定数据源:在CarListRepeater.aspx文件中,单击鼠标右键,然后点击【查看代码】,打开后置代码文件CarListRepeater.aspx.cs

ec4e6a2a068593bb2e9f3bee63a53765.png

//声明一个方法,绑定数据源

public void BindRepeater()

{

this.Repeater1.DataSource = DBHelper.getDataSet("select * from Scar").Tables[0];

this.Repeater1.DataBind();

}

第四步,调用绑定方法:在“CarListRepeater.aspx.cs”文件的Page_Load方法里,调用刚才写的方法。

f7f88f505adb0584f56725c448679a4e.png

protected void Page_Load(object sender, EventArgs e)

{

if (!IsPostBack)

{

BindRepeater();

}

}

第五步,运行测试:直接将“CarListRepeater.aspx”文件在浏览器中运行测试

cfecaa737a8ad903833e8e87c421307a.png

页面上似乎没有内容,因为Repeater控件不会自动生成任何用于布局的代码。想要将数据显示出来,我们需要继续操作。

第六步,编辑Repeater控件:回到CarListRepeater.aspx文件,将视图切换到【拆分】模式,选中Repeater控件,注意观察Repeater控件不同于DataList控件,没有编辑模板功能。只能在“源视图里编辑控件模板”。当我们在Repeater控件标签之间,输入尖括号

c53aa69ff61e2e12b6e5b226655c9947.png

模板属性

说明

标签之间内容出现次数

AlternatingItemTemplate

包含要为数据源中每个数据项都要呈现一次的 HTML 元素和控件。 通常,可以使用此模板为交替项创建不同的外观,例如指定一种与在 ItemTemplate 中指定的颜色不同的背景色。

itemtemplate轮换出现

FooterTemplate

包含在列表的结束处呈现的文本和控件。

标签之间的内容只出现一次。

HeaderTemplate

包含在列表的开始处呈现的文本和控件。

标签之间的内容只出现一次。

ItemTemplate

包含要为数据源中每个数据项都要呈现一次的 HTML 元素和控件。

标签之间的内容循环出现

SeparatorTemplate

包含在每项之间呈现的元素。典型的示例可能是一条直线(使用 hr 元素)。

间隔的内容

①简单编写模板:这里使用HeaderTemplate、ItemTemplate和FooterTemplate

970345db43b7e1a6d07bfdfbe830676d.png

运行测试:注意观察页面,总结规律。Repeater控件默认一行展示,除了用户自定义的模板,不会自动生成任何用于布局 的代码。

ca5957e3d7398675ac2c15f6df4bcd57.png

②优化模板:比如增加换行标签

3fe43f53d809451229accb6a2b015f13.png

③呈现数据:如呈现数据源里的车型名称,使用 获取

c383acbb677e607a40f611c00b823083.png

④编写完整样式:呈现数据、美化样式

d76237f8c20068cca138a9924d5e528c.png

完整代码:

Repeater—王迪

车型展示——头部

--%>

<%#Eval(%22picture%22)%20%>

展示完毕——尾部--%>

示例练习3:在页面增加搜索功能

要求:在当前页面中,增加一个搜索功能,允许通过汽车名称搜索

第一步,设计搜索框:在CarListRepeater.aspx文件,设计搜索框,调用控件

d8a1656dd6fccba30c09444045a23e70.png

请输入:

第二步,给按钮添加事件:双击【搜索】按钮,进入事件编写

1a3def98566aa8b3e1bab4e821c534bc.png

protected void Button1_Click(object sender, EventArgs e)

{

//获取用户输入的内容

string name = this.TextBox1.Text;

//声明查询语句,这里使用like进行模糊查询

string sql = "select * from Scar where CarName like '%"+name+"%'";

this.Repeater1.DataSource = DBHelper.getDataSet(sql).Tables[0];

this.Repeater1.DataBind();

}

第三步,允许测试:

40e65845b5b2d4459225aa35f0830222.png

案例思考:如果用户在搜索框里,什么都没有输入,搜索结果会是什么?为什么会是这样的结果?

2.2  在 Repeater 控件中删除数据

Repeater 控件不支持编辑、删除、排序等功能,所有的事件必须自行编写代码处理。当点 击 Repeater 中的按钮控件时会触发 Repeater 控件的 ItemCommand 事件。为了标识单击的按钮, 可以设置按钮的 CommandName 属性。在进行删除或者编辑操作时,都需要本行车型的编号,可以 设置按钮的 CommandArgument 属性来保存本行的车型编号。

示例练习4:在 Repeater 控件中删除数据

版权所有 IT知识库 CopyRight © 2000-2050 IT知识库 IT610.com , All Rights Reserved.

京ICP备09083238号

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值