按经典ASP的列标题TD排序

问题描述 投票:1回答:1

我喜欢按TD列排序。打开网页时,按ID排序。然后,当我单击“姓氏或名字”时,它将按ASC排序,如果再次单击它,则将按DESC排序。

这是我的代码,我有一个错误。

您能帮忙吗?

谢谢。

Dim sOrder
sOrder="ASC"
If Request("sort")="ASC" Then
 sOrder="DESC"
End If
%>
<table>
<tr>
<td>Class</td>
<% If sOrder = "ASC" Then %>
<td "<a href='?sort=" & sOrder & ">" >Last name</td>
<% Else %>
<td "<a href='?sort=" & sOrder & ">">Last name</td>
<% End If %>
<% If sOrder = "ASC" Then %>
<td "<a href='?sort=" & sOrder & ">" >First name</td>
<% Else %>
<td "<a href='?sort=" & sOrder & ">">First name</td>
<% End If %>
</tr>

<%
rsSQL.Open "select * from students ORDER BY " & sColumn & " " & sOrder, conn
If Not rsSQL.EOF Then
        nNo = 1
        While Not rsSQL.EOF
        ID          = rsSQL.Fields("ID")
        Lastname            = rsSQL.Fields("Lastname")
        Firstname       = rsSQL.Fields("Firstname")
%>

<tr>
<td><%= ID%></td>
<td><%= Lastname%></td>
<td><%= Firstname%></td>
</tr>
<%
        rsSQL.MoveNext  
        nNo = nNo + 1
        Wend    
rsSQL.Close
    End If
%>
javascript asp-classic
1个回答
1
投票

尝试

Dim sOrder, sColumn
sColumn="ID"
sOrder=""
If Request.QueryString("sort") = "ASC" Then
    sOrder = "DESC"
End if
If Request.QueryString("col") = "Firstname" OR Request.QueryString("col") = "Lastname" Then 
    sColumn = Request.QueryString("col")
End If
%>
<table>
    <tr>
        <td>Class</td>
<% If sColumn = "Lastname" AND sOrder = "ASC" Then %>
        <td><a href="?col=Lastname&amp;sort=DESC">Last name</a></td>
<% Else %>
        <td><a href="?col=Lastname&amp;sort=ASC">Last name</a></td>
<% End If %>
<% If sColumn = "Firstname" AND sOrder = "ASC" Then %>
        <td><a href="?col=Firstname&amp;sort=DESC">First name</a></td>
<% Else %>
        <td><a href="?col=Firstname&amp;sort=ASC">First name</a></td>
<% End If %>
    </tr>

<%
rsSQL.Open "select * from students ORDER BY " & sColumn & " " & sOrder, conn
...
%>

    <tr>
        <td><%= ID %></td>
        <td><%= Lastname %></td>
        <td><%= Firstname %></td>
    </tr>
<%
...
%>
© www.soinside.com 2019 - 2024. All rights reserved.