当前位置: 移动技术网 > IT编程>开发语言>.net > ASP.NET对无序列表批量操作的三种方法小结

ASP.NET对无序列表批量操作的三种方法小结

2017年12月12日  | 移动技术网IT编程  | 我要评论

我的军旅生涯,吕仙枕黄梁未熟,s的唯一 m的绝对

本篇介绍服务器端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;
}

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

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网