当前位置: 首页 > 编程笔记 >

ASP.NET批量操作基于原生html标签的无序列表的三种方法

宇文鸣
2023-03-14
本文向大家介绍ASP.NET批量操作基于原生html标签的无序列表的三种方法,包括了ASP.NET批量操作基于原生html标签的无序列表的三种方法的使用技巧和注意事项,需要的朋友参考一下

在网页开发中,经常要用到无序列表。事实上在符合W3C标准的div+css布局中,无序列表被大量使用,ASP.NET虽然内置了BulletedList控件,用于创建和操作无序列表,但感觉不太好用。本篇介绍服务器端ASP.NET批量操作基于原生html标签的无序列表的三种方法。

方法一,将li元素做成html控件,加上id,用FindControl方法。

aspx代码:

<form id="form1" runat="server"> 
<ul> 
<li id="li1" runat="server">初始值1</li> 
<li id="li2" runat="server">初始值2</li> 
<li id="li3" runat="server">初始值3</li> 
<li id="li4" runat="server">初始值4</li> 
<li id="li5" runat="server">初始值5</li> 
<li id="li6" runat="server">初始值6</li> 
<li id="li7" runat="server">初始值7</li> 
<li id="li8" runat="server">初始值8</li> 
</ul> 
<asp:Button ID="Button1" runat="server" Text="Button" onclick="Button1_Click" /> 
</form>

aspx.cs代码:

protected void Button1_Click(object sender, EventArgs e) 
{ 
//单击按钮后批量改变li元素的内联文本值及样式 
for (int i = 1; i <= 8; i++) 
{ 
HtmlGenericControl li = this.FindControl("li" + i) as HtmlGenericControl; 
li.InnerHtml = "新值" + i.ToString(); 
li.Attributes.CssStyle.Value = "color:red"; 
} 
}

方法二,将ul、li元素做成html控件,用ul控件的Controls集合遍历。

aspx代码:

<form id="form1" runat="server"> 
<ul id="ul1" runat="server"> 
<li runat="server">初始值1</li> 
<li runat="server">初始值2</li> 
<li runat="server">初始值3</li> 
<li runat="server">初始值4</li> 
<li runat="server">初始值5</li> 
<li runat="server">初始值6</li> 
<li runat="server">初始值7</li> 
<li runat="server">初始值8</li> 
</ul> 
<asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_Click" /> 
</form>

aspx.cs代码:

private int counter = 1; 
protected void Button1_Click(object sender, EventArgs e) 
{ 
//单击按钮后批量改变li元素的内联文本值及样式 
foreach (Control control in ul1.Controls) 
{ 
if (control is HtmlGenericControl) 
{ 
HtmlGenericControl li = control as HtmlGenericControl; 
li.InnerHtml = "新值" + (counter++).ToString(); 
li.Attributes.CssStyle.Value = "color:red"; 
} 
} 
}

方法三,利用HtmlAgilityPack,对元素以Dom方式操作。

aspx代码:

<form id="form1" runat="server"> 
<ul id="ul1" runat="server"> 
<li>初始值1</li> 
<li>初始值2</li> 
<li>初始值3</li> 
<li>初始值4</li> 
<li>初始值5</li> 
<li>初始值6</li> 
<li>初始值7</li> 
<li>初始值8</li> 
</ul> 
<asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_Click" /> 
<asp:Button ID="Button2" runat="server" Text="测试空回发" /> 
</form>

aspx.cs代码:

protected void Button1_Click(object sender, EventArgs e) 
{ 
//单击按钮后批量改变li元素的内联文本值及样式 
HtmlDocument htmlDoc = new HtmlDocument(); 
htmlDoc.LoadHtml(ul1.InnerHtml); 
HtmlNodeCollection lis = htmlDoc.DocumentNode.SelectNodes("li"); 
for (int i = 0; i < lis.Count; i++) 
{ 
lis[i].InnerHtml = "新值" + (i + 1).ToString(); 
lis[i].Attributes.Add("style", "color:red"); 
} 
ul1.InnerHtml = htmlDoc.DocumentNode.InnerHtml; 
}

以上三种方法各有优缺点,可根据实际情况选用。

 类似资料:
  • 本文向大家介绍MySQL批量替换HTML标签,包括了MySQL批量替换HTML标签的使用技巧和注意事项,需要的朋友参考一下 1 前因 前段时间维护的一个WordPress小网站被黑,分析源码发现内容中多出了一段JavaScript代码: 访问页面的时候,会跳转到黑客的广告页面: 经过追踪,最后发现是在MySQL中被注入了以上代码,所以需要在wp_posts表中把这些内容都替换掉 (当然后来加强了这

  • 主要内容:功能排序功能排序 New : HTML5 新标签 标签 描述 基础   <!DOCTYPE>  定义文档类型。 <html> 定义一个 HTML 文档 <title> 为文档定义一个标题 <body> 定义文档的主体 <h1> to <h6> 定义 HTML 标题 <p> 定义一个段落 <br> 定义简单的折行。 <hr> 定义水平线。 <!--...--> 定义一个注释 格式   <acronym> H

  • 主要内容:按字母顺序排列按字母顺序排列 New : HTML5新标签 标签 描述 <!--...--> 定义注释 <!DOCTYPE> 定义文档类型 <a> 定义超文本链接 <abbr> 定义缩写 <acronym> 定义只取首字母的缩写,不支持HTML5 <address> 定义文档作者或拥有者的联系信息 <applet> HTML5中不赞成使用。定义嵌入的 applet。 <area> 定义图像映射内部的区域 <ar

  • 问题内容: 当我执行以下代码时,一切都很好: 结果是: 但是当我执行以下代码时: 结果是: 为什么在这里抛出异常? 问题答案: 问题是,参考实现()包含一个错误:当您通过名称检索列,它使用的,而 不是 在,为此逆着它使用JDBC规范的其余部分检索值。此错误使得不可能通过来从行集中检索值。 Oracle的错误是http://bugs.sun.com/bugdatabase/view_bug.do?b

  • 主要内容:顺序表插入元素,顺序表删除元素,顺序表查找元素,顺序表更改元素我们学习了 顺序表及初始化的过程,本节学习有关顺序表的一些基本操作,以及如何使用 C 语言实现它们。 顺序表插入元素 向已有顺序表中插入数据元素,根据插入位置的不同,可分为以下 3 种情况: 插入到顺序表的表头; 在表的中间位置插入元素; 尾随顺序表中已有元素,作为顺序表中的最后一个元素; 虽然数据元素插入顺序表中的位置有所不同,但是都使用的是同一种方式去解决,即:通过遍历,找到数据元素要插入的位

  • 本文向大家介绍基于python的列表list和集合set操作,包括了基于python的列表list和集合set操作的使用技巧和注意事项,需要的朋友参考一下 以下是一些python的list和set的基本操作 1. list的一些操作 输出结果: 2.s et基本操作 输出结果: 以上这篇基于python的列表list和集合set操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多