0

私のプログラム:

Active Directory からデータを取得する ListView があります。ユーザーは文字列 (姓またはその一部) を TextBox に入力します。ListView よりも、TextBox からの同じ文字列を持つすべての AD ユーザーを一覧表示します。すべての行 (行) には、ユーザーに関する詳細情報を取得するためのボタン "Anzeigen" があります。

ASPX:

<asp:ListView runat="server" ID="myListView">

        <LayoutTemplate>
            <table id="UserTable" runat="server" border="0" cellspacing="10" cellpadding="2">
                <tr runat="server" id="Tr1" style="background-color:#E5E5FE">
                    <th runat="server"><asp:LinkButton ID="lnkBenutzer" runat="server" CommandName="Sort" CommandArgument="Benutzer" onsorting="ListView1_Sorting">Benutzer</asp:LinkButton></th>
                    <th runat="server"><asp:LinkButton ID="lnkemail" runat="server" CommandName="Sort" CommandArgument="eMail" onsorting="ListView1_Sorting" >eMail</asp:LinkButton></th>
                    <th runat="server"><asp:LinkButton ID="lnkVorname" runat="server" CommandName="Sort" CommandArgument="Vorname" onsorting="ListView1_Sorting" >Vorname</asp:LinkButton></th>
                    <th runat="server"><asp:LinkButton ID="lnkNachname" runat="server" CommandName="Sort" CommandArgument="Nachname" onsorting="ListView1_Sorting" >Nachname</asp:LinkButton></th>
                    <th runat="server"><asp:LinkButton ID="lnkTelefon" runat="server" CommandName="Sort" CommandArgument="Telefon" onsorting="ListView1_Sorting"  >Telefon</asp:LinkButton></th>
                </tr>
                <tr runat="server" id="ItemPlaceholder">
                </tr>
            </table>
        </LayoutTemplate>

        <ItemTemplate>

            <tr runat="server"> 

                <td align="left" ><asp:Label ID="Label1" Text='<%# Eval("Benutzer") %>' runat="server" /></td>
                <td align="left"><asp:Label ID="Label2" Text='<%# Eval("eMail") %>' runat="server" /></td>
                <td align="left"><asp:Label ID="Label3" Text='<%# Eval("Vorname") %>' runat="server" /></td>
                <td align="left"><asp:Label ID="Label4" Text='<%# Eval("Nachname") %>' runat="server" /></td>
                <td align="left"><asp:Label ID="Label5" Text='<%# Eval("Telefon") %>' runat="server" /></td>

             <td align="left"><asp:Button ID="Button1" Text="Anzeigen" OnCommand="Button1_Command" CommandName="Anzeigen" CommandArgument="MyArgument" runat="server" /></td>

            </tr>

        </ItemTemplate>

        <AlternatingItemTemplate>

            <tr style="background-color:#EFEFEF"> 

                <td align="left" ><asp:Label ID="Label1" Text='<%# Eval("Benutzer") %>' runat="server" /></td>
                <td align="left"><asp:Label ID="Label2" Text='<%# Eval("eMail") %>' runat="server" /></td>
                <td align="left"><asp:Label ID="Label3" Text='<%# Eval("Vorname") %>' runat="server" /></td>
                <td align="left"><asp:Label ID="Label4" Text='<%# Eval("Nachname") %>' runat="server" /></td>
                <td align="left"><asp:Label ID="Label5" Text='<%# Eval("Telefon") %>' runat="server" /></td>

             <td align="left"><asp:Button ID="Button1" Text="Anzeigen" OnCommand="Button1_Command" CommandName="Anzeigen" CommandArgument="MyArgument" runat="server" /></td> 

            </tr>

        </AlternatingItemTemplate>

CS ファイル:

...

protected void ListView1_Sorting(object sender, ListViewSortEventArgs e)
        {
            //here???
        }

...

私が欲しいもの:

ユーザーが LinkBut​​ton "Benutzer" をクリックした場合、リストはアルファベット順に並べ替える必要があります:PI サイトhttp://www.codeproject.com/Articles/24570/Complete-ListView-in-ASP-NET-3-5を参照してください。しかし、例とダウンロードファイルには、このソート方法は存在しません:(

リストを並べ替える方法がわかりません。

したがって、リストにデータを入力します。

protected void btnBenutzerSuchen_Click(object sender, EventArgs e)
        {
            DirectoryEntry Entry = new DirectoryEntry("LDAP://" + "Domain");

            string filter = "(&(objectClass=user)(objectCategory=person)(cn=" + txtBenutzer.Text + "*))";

            DirectorySearcher Searcher = new DirectorySearcher(Entry, filter);

            var q = from s in Searcher.FindAll().OfType<SearchResult>()
                    select new
                    {
                        Benutzer = GetProperty(s, "sAMAccountName"),
                        eMail = GetProperty(s, "mail"),
                        Vorname = GetProperty(s, "givenName"),
                        Nachname = GetProperty(s, "sn"),
                        Telefon = GetProperty(s, "telephoneNumber")
                    };

            this.myListView.DataSource = q;
            this.myListView.DataBind();

        }

タラソフ

4

1 に答える 1

0

ここでは、データ名に従ってデータをソートします。そのためには、datakey を rowdataBound イベントに渡す必要があります。

お気に入り' :

protected void gvEmployeeList_RowCommand(object sender, GridViewCommandEventArgs e)
{
    if (e.CommandName == "name")
    {
        int index = Convert.ToInt32(e.CommandArgument);
        GridViewRow selectedRow = gvEmployeeList.Rows[index];
        string deptID = gridview1.DataKeys[index].Value.ToString().Trim();
         DataTable dtEmplist = new DataTable();
        dtEmplist = getFilterEmployeeList(deptID);
        if (dtEmplist.Rows.Count > 0)
        {
            gridview1.DataSource = dtEmplist;
            gridview1.DataBind();
        }
        else
        {
            lblMsg.Text = "No Data Available";
        }
    }
}

データキー取得後

並べ替え (GridViewSortEventArgs e)

e.sortExpression プロパティ。

それは私の友人を助けるでしょう....

于 2012-07-23T09:58:17.663 に答える