篆体字网 > 知识库

listview控件

来源:篆体字网 2024-01-03 13:30:10 作者:篆字君

当你编写以用户为中心的应用程序时,总需要某种形式的数据集,起码来说,你需要从一个数据源如关系数据库或XML文件检索数据,在显示给用户之前先要进行格式化,尽管ASP.NET之前的版本就提供了以数据为中心的显示控件如GridView,但GridView的输出仍然是限制在一个table组件中的,而且这些控件缺乏专业Web开发人员需要的可自定义和可扩展特性,有时候你想要完全控制由数据绑定控件产生的HTML标记的外观,这正是ListView控件的优势,ListView控件不是使用额外的标记来封装它的输出内容,而是靠你指定的精确的HTML描述,使用ListView控件内置的模板就可以指定精确的标记,它提供了非常优秀的自定义和扩展特性,使用这些特性,你可以以任何格式显示数据,使用模板和样式,同时用最少的代码执行CURD(创建、读取、更新、删除)操作。我们先看一下ListView支持的模板模板用途AlternatingItemTemplate交替项目模板用不同的标记显示交替的项目,便于查看者区别连续不断的项目EditItemTemplate编辑项目模板控制编辑时的项目显示EmptyDataTemplate空数据模板控制ListView数据源返回空数据时的显示EmptyItemTemplate空项目模板控制空项目的显示GroupSeparatorTemplate组分隔模板控制项目组内容的显示GroupTemplate组模板为内容指定一个容器对象,如一个表行、div或span组件InsertItemTemplate插入项目模板用户插入项目时为其指定内容ItemSeparatorTemplate项目分隔模板控制项目之间内容的显示ItemTemplate项目模板控制项目内容的显示LayoutTemplate布局模板指定定义容器对象的根组件,如一个table、div或span组件,它们包装ItemTemplate或GroupTemplate定义的内容。SelectedItemTemplate已选择项目模板指定当前选中的项目内容的显示最关键的两个模板是LayoutTemplate和ItemTemplate,正如名字暗示的那样,LayoutTemplate为ListView控件指定了总的标记,而ItemTemplate指定的标记用于显示每个绑定的记录一、LayoutTemplate和ItemTemplate模板标识定义控件的主要布局的根模板。它包含一个占位符对象,例如表行 (tr)、div 或 span 元素。此元素将由 ItemTemplate 模板或 GroupTemplate 模板中定义的内容替换。使用 LayoutTemplate 属性可以为 ListView 控件的根容器定义自定义用户界面 (UI)。LayoutTemplate 模板是 ListView 控件所必需的。LayoutTemplate 内容必须包含一个占位符控件,例如由 ItemTemplate 模板定义的项表行 (tr) 元素。占位符控件必须将 runat 属性 (Attribute) 设置为“server”,将 ID 属性 (Attribute) 设置为 ItemPlaceholderID 或 GroupPlaceholderID 属性 (Property) 的值(具体取决于 ListView 控件是否使用组)。例如:前端代码:ListView演示前端代码' />
' />

后台代码:ListView演示后台代码public partial class _Default : System.Web.UI.Page{protected void Page_Load(object sender, EventArgs e){Employee e1 = new Employee { Name = "lfm1", Age = 30 };Employee e2 = new Employee { Name = "lfm2", Age = 30 };Employee e3 = new Employee { Name = "lfm3", Age = 30};Employee e4 = new Employee { Name = "lfm4", Age = 30};Employee e5 = new Employee { Name = "lfm5", Age = 30};Employee e6 = new Employee { Name = "lfm6", Age = 30 };Employee[] employees = { e1,e2,e3,e4,e5,e6};ListView1.DataSource = employees;ListView1.DataBind();}protected void Button1_Click(object sender, EventArgs e){}}class Employee{public string Name { get; set; }public int Age { get; set; }public int Sex { get; set; }}浏览器中得到的代码为:浏览器中显示的代码
lfm1
30
lfm2
30
lfm3
30
lfm4
30
lfm5
30
lfm6
30
这里要注意LayoutTemplate中的即为占位符,它将在绑定时被ItemTemplate中的内容替换掉二、分组的应用前端代码:前端代码
<%#Eval("ID") %><%# Eval("name") %><%# Eval("age") %>
通过itemPlaceholderContainer知道这是一段要被替换的元素,而且是根据tr进行行替换。然后再配合LayoutTemplate形成分组。我们是如何来定义每行的列数的呢?只需要在ListView里添加一个属性定义我们这里设置GroupItemCount属性的值为4,也就代表我们的每个Group里面包含的4项。

上一篇:seo观察

下一篇:mhdd怎么用

相关阅读