欢迎光临
我们一直在努力

ASP常见问题及解答(8)-ASP教程,ASP技巧

建站超值云服务器,限时71元/月

1.表格排序

表格排序是对表格而言的,与表格的生成无关。就是说,无论用何种方式产生的表格排序时都一样。这是排序函数,很简单。

分升序和降序,要求传入参数:obj 表格名或id; n 排序列,第一列为0

<script>

function table_sort_asc(obj,n) {

var i,j;

var tab = eval("document.all."+obj);

if(tab.tagname != "table") return;

for(i=0;i<tab.rows.length-1;i++)

for(j=i+1;j<tab.rows.length;j++)

if(tab.rows[i].cells[n].innerhtml > tab.rows[j].cells[n].innerhtml)

tab.rows[i].swapnode(tab.rows[j]);

}

function table_sort_desc(obj,n) {

var i,j;

var tab = eval("document.all."+obj);

if(tab.tagname != "table") return;

for(i=0;i<tab.rows.length-1;i++)

for(j=i+1;j<tab.rows.length;j++)

if(tab.rows[i].cells[n].innerhtml < tab.rows[j].cells[n].innerhtml)

tab.rows[i].swapnode(tab.rows[j]);

}

</script>

<html>

<head>

<script>

//方法1:

function sorttable(){

var arrend = [];

var arrnotbegin = [];

for (i=0; i < document.all.table1.rows.length; i++) {

var otr = new object();

for (j=0; j < document.all.table1.rows(i).cells.length; j++) {

var strnode = document.all.table1.rows(i).cells(j).innertext;

switch(j)

{

case 0:

otr.time = strnode;

break;

case 1:

otr.state = strnode;

break;

case 2:

otr.topic = strnode;

break;

default:

break;

}

}

if(otr.state == "未开始")

{

arrnotbegin[arrnotbegin.length] = otr;

}else{

arrend[arrend.length] = otr;

}

}

arrnotbegin.sort(function(){var a1=arguments[0];var a2=arguments[1];if(a1.time>a2.time){return 1}else if(a1.time<a2.time){return -1}else{return 0}});

arrend.sort(function(){var a1=arguments[0];var a2=arguments[1];if(a1.time>a2.time){return 1}else if(a1.time<a2.time){return -1}else{return 0}});

var strtable = "<table id=table1 border=1>";

for(var j=0; j<arrnotbegin.length; j++){

strtable += "<tr>";

strtable += "<td>" + arrnotbegin[j].time + "</td>";

strtable += "<td>" + arrnotbegin[j].state + "</td>";

strtable += "<td>" + arrnotbegin[j].topic + "</td>";

strtable += "</tr>";

}

for(var j=0; j<arrend.length; j++){

strtable += "<tr>";

strtable += "<td>" + arrend[j].time + "</td>";

strtable += "<td>" + arrend[j].state + "</td>";

strtable += "<td>" + arrend[j].topic + "</td>";

strtable += "</tr>";

}

strtable += "</table>"

document.all.table1.outerhtml = strtable;

}

//方法2:

//这里的td表示要排序的列

function sorttable(){

var xmldoc = new activexobject("microsoft.xmldom");

xmldoc.async = false;

xmldoc.loadxml(document.all.table1.innerhtml);

var xsldoc = new activexobject("microsoft.xmldom");

xsldoc.async = false;

var strxsl = +

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/xsl/transform" version="1.0"> +

<xsl:template match="/tbody"> +

<xsl:for-each select="tr" > +

<xsl:sort select="td[2]" order="descending"/> +

<xsl:sort select="td[1]" /> +

<xsl:copy> +

<xsl:apply-templates select="@*|node()" /> +

</xsl:copy> +

</xsl:for-each> +

</xsl:template> +

<xsl:template match="@*|node()"> +

<xsl:copy> +

<xsl:apply-templates select="@*|node()" /> +

</xsl:copy> +

</xsl:template> +

</xsl:stylesheet>

xsldoc.loadxml(strxsl);

var a = xmldoc.transformnode(xsldoc);

a = a.substring(39);

document.all.table1.outerhtml = <table id="table1"> + a + </table>;

}

</script>

</head>

<body>

<table id="table1" border="1">

<tr>

<td>22:30</td>

<td>未开始</td>

<td>倩女幽魂</td>

</tr>

<tr>

<td>21:30</td>

<td>未开始</td>

<td>tv三贱客</td>

</tr>

<tr>

<td>20:30</td>

<td>完</td>

<td>娱乐串串烧</td>

</tr>

<tr>

<td>23:30</td>

<td>未开始</td>

<td>篮球大本营</td>

</tr>

<tr>

<td>22:15</td>

<td>未开始</td>

<td>新闻时间</td>

</tr>

</table>

<input type="button" value="排序" onclick="sorttable();">

</body>

</html>

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » ASP常见问题及解答(8)-ASP教程,ASP技巧
分享到: 更多 (0)

相关推荐

  • 暂无文章