欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-02-20 22:21:22
在网页开发中,经常要用到无序列表。事实上在符合w3c标准的div+css布局中,无序列表被大量使用,asp.net虽然内置了bulletedlist控件,用于创建和操作无序...

在网页开发中,经常要用到无序列表。事实上在符合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; 
}

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