Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/asp.net/32.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/clojure/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# ASP.NET网格视图排序(未使用数据库)_C#_Asp.net - Fatal编程技术网

C# ASP.NET网格视图排序(未使用数据库)

C# ASP.NET网格视图排序(未使用数据库),c#,asp.net,C#,Asp.net,我对asp.net中的数据网格视图有问题。代码如下: using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; using Lab1; public partial class Lab2_TicketsView : System.Web.UI.Page { protec

我对asp.net中的数据网格视图有问题。代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using Lab1;

public partial class Lab2_TicketsView : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        lblViewTicketCategoryError.Visible = false;
        lblViewTicketUserError.Visible = false;

        if(!IsPostBack)
        {
            string empty = "";
            string defaultOption = "All";

            ddlTicketViewCategory.Items.Add(empty);
            ddlTicketViewUsers.Items.Add(defaultOption);

            foreach(Category c in CategoryUtility.Instance.GetCategories())
            {
                ddlTicketViewCategory.Items.Add(c.Name);
            }

            var Users = from usr in UserUtility.Instance.GetUsers()
                        select new
                        {
                            Name = usr.FirstName + " " + usr.LastName,
                            usr.Email
                        };

            ddlTicketViewUsers.DataTextField = "Name";
            ddlTicketViewUsers.DataValueField = "Email";
            ddlTicketViewUsers.DataSource = Users;
            ddlTicketViewUsers.DataBind();

            showTicketList();
        }
    }

    protected void showTicketList()
    {
        var Tickets = from ticket in TicketsUtility.Instance.GetTickets()
                      select new
                      {
                          ticket.Title,
                          Name = ticket.User.FirstName + " " + ticket.User.LastName,
                          ticket.Cateogry,
                          ticket.Description
                      };

        dgvTickets.DataSource = Tickets;
        dgvTickets.DataBind();
    }
    protected void btnFilter_Click(object sender, EventArgs e)
    {
        if(ddlTicketViewCategory.SelectedItem.Text == "")
        {
            lblViewTicketCategoryError.Visible = true;
            lblViewTicketCategoryError.Text = "Please select a category";
        }
        else if(ddlTicketViewUsers.SelectedItem.Text == "")
        {
            lblViewTicketUserError.Visible = true;
            lblViewTicketUserError.Text = "Please select a user";
        }
        else
        {
            showTicketList();
        }

    }
}
            if (ddlTicketViewCategory.SelectedItem != null)
            {
                var FilteredList = Tickets.Where(Filter => Filter.Category == ddlTicketViewCategory.SelectedItem.ToString()).ToList();
            }
            dgvTickets.DataSource = FilteredList;
            dgvTickets.DataBind();

输出显示在栅格视图中。我正在尝试根据从下拉列表中选择的选项对列表进行排序。没有使用数据库,只使用提供的库中的文本文件和方法(CategoryUtility和UserUtility来自此库)。如何使网格视图中显示的数据基于从下拉列表中选择的选项?SelectedItem.Selected会扮演任何角色吗?我是否使用LINQ?如果是,在哪里以及如何使用?任何输入都将不胜感激。

这是为了过滤其中一个,您也可以对其他输入应用相同的过程

            if (ddlTicketViewCategory.SelectedItem != null)
            {
                var FilteredList = Tickets.Where(Filter => Filter.Category == ddlTicketViewCategory.SelectedItem.ToString()).ToList();
            }
            dgvTickets.DataSource = FilteredList;
            dgvTickets.DataBind();