Как включить автоматическую сортировку данных IEnumerable в GridView? - PullRequest
14 голосов
/ 31 марта 2010

Как включить автоматическую сортировку моего BLL, который возвращает список CustomerList: List в GridView?

Customer - это мой строго типизированный класс, а CustomerList - это список клиентов.

Я знаю, что один из подходов состоит в том, чтобы установить для свойства AllowSorting значение true в GridView, обработать событие OnSorting и вызвать метод сортировки, определенный в моем классе CustomerList.

Однако мне бы хотелось, чтобы решение было автоматическим в том смысле, что мне не нужно обрабатывать событие OnSorting, оно должно быть похоже на то, как GridView выполняет автоматическую сортировку для DataView, DataTable и DataSet.

Есть ли интерфейс, который мне нужно реализовать в классе CustomerList или Customer, который включит эту функцию?

альтернативный текст http://img260.imageshack.us/img260/3373/aa479347gridviewfg21enu.gif

Ответы [ 2 ]

7 голосов
/ 31 марта 2010

Хорошо, я понял это. Вот решение:

  1. Свяжите BLL с ObjectDataSource.
  2. Предоставьте перегруженные методы для метода select в вашем BLL, чтобы поддерживать подкачку и сортировку.
  3. Укажите SortParameterName в ObjectDataSource. Это имя входного параметра строки вашего метода выбора в вашем BLL.

Для получения дополнительной информации см .: http://msdn.microsoft.com/en-us/library/aa479347.aspx

Вот пример, это всего лишь пример quck для демонстрации. Я не поддерживал направление сортировки или оптимизировал код и т. Д .:

namespace CodeSamples.DAL
{
    public static class DAL
    {
        public static CustomerList GetCustomerList(string SortExpression)
        {
            return GetCustomerList(int.MaxValue, 0, SortExpression);
        }

        public static CustomerList GetCustomerList()
        {
            return GetCustomerList(int.MaxValue, 0,String.Empty);
        }

        public static CustomerList GetCustomerList(int maximumRows, int startRowIndex, string SortExpression)
        {
            const string query = "Select * from Customers";
            CustomerList customers = new CustomerList();


            SqlConnection conn = new SqlConnection("Data Source=Win2k8;Initial Catalog=NorthWind;User ID=sa;Password=XXXXX");
            SqlCommand command = new SqlCommand(query, conn);
            conn.Open();
            SqlDataReader reader = command.ExecuteReader();

            ArrayList rows = new ArrayList();

            while (reader.Read())
            {
                object[] values = new object[reader.FieldCount];
                reader.GetValues(values);
                rows.Add(values);
            }

            conn.Close();

            int currentIndex = 0;
            int itemsRead = 0;
            int totalRecords = rows.Count;

            foreach (object[] row in rows)
            {
                if (currentIndex >= startRowIndex && itemsRead <= maximumRows)
                {
                    customers.Add(new Customer { Name = row[1].ToString(), ID = row[0].ToString(), ContactName = row[2].ToString() });
                    itemsRead++;
                }
                currentIndex++;
            }


        CustomerList sortedCustomers = new CustomerList();

        string sortBy = SortExpression;
        bool isDescending = false;

        if (SortExpression.ToLowerInvariant().EndsWith(" desc"))
        {
            sortBy = SortExpression.Substring(0, SortExpression.Length - 5);
            isDescending = true;
        }         

        var sortedList = from customer in customers
                         select customer;

        switch (sortBy)
        {
            case "ID":
                sortedList = isDescending ? sortedList.OrderByDescending(cust => cust.ID) : sortedList.OrderBy(cust => cust.ID);
                break;

            case "Name":
                sortedList = isDescending ? sortedList.OrderByDescending(cust => cust.Name) : sortedList.OrderBy(cust => cust.Name);
                break;

            case "ContactName":
                sortedList = isDescending ? sortedList.OrderByDescending(cust => cust.ContactName) : sortedList.OrderBy(cust => cust.ContactName);
                break;

        }

        foreach (Customer x in sortedList)
        {
            sortedCustomers.Add(x);
        }    

            return sortedCustomers;
        }
    }  

    public class CustomerList : List<Customer>
    {

    } 

    public class Customer
    {
        public Customer()
        {
        }

        public Customer(string Name, string id)
        {
            this.Name = Name;
            ID = id;
        }
        public string ID
        {
            get;
            set;
        }

        public string Name
        {
            get;
            set;
        }

        public string ContactName
        {
            get;
            set;
        }


    }
}

На странице ASPX:

  <asp:GridView ID="GridView1" runat="server" AllowPaging="True" 
            AutoGenerateColumns="False" DataSourceID="ObjectDataSource1" 
            AllowSorting="True">
            <Columns>
                <asp:BoundField DataField="ID" HeaderText="ID" SortExpression="ID" />
                <asp:BoundField DataField="Name" HeaderText="Name" SortExpression="Name" />
                <asp:BoundField DataField="ContactName" HeaderText="ContactName" SortExpression="ContactName" />
            </Columns>
        </asp:GridView>
        <asp:ObjectDataSource ID="ObjectDataSource1" runat="server" 
            SelectMethod="GetCustomerList" SortParameterName="SortExpression"
            TypeName="CodeSamples.DAL.DAL">
        </asp:ObjectDataSource>

Для получения дополнительной информации см .: http://msdn.microsoft.com/en-us/library/aa479347.aspx

0 голосов
/ 08 января 2013

Вы можете сделать ту же логику в DAL, сохранив выражение и направление сортировки в сессиях.Получите направление Sortexpression n от метода сортировки вида сетки и выполните сортировку в DAL, используя эти параметры. НО, чтобы позаботиться об исключении при установке e.cancel = true

protected void GridView1_Sorting(object sender, GridViewSortEventArgs e)
        {
     \\ Take sortexpression n direction
       e.cancel = true 
        }

также см. http://forums.asp.net/t/1344883.aspx

...