Как отобразить поля иерархического класса в Telerik RadGrid? - PullRequest
2 голосов
/ 11 января 2012

Метод GetEmployeeDetails () возвращает значение типа Employee.Мне нужно отобразить это значение в Telerik RadGrid таким образом, чтобы, когда мы щелкали по строкам Employee, оно расширяло строку соответствующих полей класса Address под строкой Employee.Ниже приведена структура класса Employee.

    class Employee
    {
        string EmpId;
        string Name;
        int Age;
        List<Address> address;
    }

    class Address
    {
        string Street;
        string City;
        int Zip;
    }

Ниже приведен код для отображения сведений об сотруднике во время выполнения на странице ASP с использованием Telerik RadGrid.Но его отображают только первый уровень - поля класса Employee и поля Address с пустыми значениями.Не могли бы вы помочь мне выйти из этой проблемы ...?

    protected void Page_Load(object sender, EventArgs e)
    {
        List<Employee> empList = GetEmployeeDetails();

        DataSet dataset = new DataSet("DataSet");

        System.Data.DataTable dt1 = new System.Data.DataTable();
        dt1.TableName = "Employee";
        dt1.Columns.Add("EmpId");
        dt1.Columns.Add("Name");
        dt1.Columns.Add("Age");
        dataset.Tables.Add(dt1);

        System.Data.DataTable dt2 = new System.Data.DataTable();
        dt2.TableName = "Address";
        dt2.Columns.Add("EmpId");
        dt2.Columns.Add("Street");
        dt2.Columns.Add("City");
        dt2.Columns.Add("Zip");
        dataset.Tables.Add(dt2);

        foreach (Employee emp in empList)
        {
            dt1.Rows.Add(new object[] { emp.empId, emp.name, emp.age });
            foreach (Address add in emp.address)
            {
                dt2.Rows.Add(new object[] {emp.empId, add.street, add.city, add.zip });
            }
        }

        DataRelation rel = new DataRelation("rel", dataset.Tables["Employee"].Columns["EmpId"], dataset.Tables["Address"].Columns["EmpId"]);
        dataset.Relations.Add(rel);
        RadGrid1.DataSource = dataSet;
        RadGrid1.DataBind();

    }

1 Ответ

4 голосов
/ 13 января 2012

Для сайта Telerik вы должны использовать событие RadGrid1_NeedDataSource для привязки, если вы хотите иметь иерархию.

enter image description here

Я заставил его работать, выполнивследующие.(Кстати, я использовал ваши классы и код, поэтому имитировать его будет легко, так как я опубликую весь код. Вы также пропустили метод GetEmployeeDetails (), поэтому я сделал свой собственный:

   private List<Employee> GetEmployeeDetails()
   {
        List<Employee> myEmployees = new List<Employee>();

        Employee Steve = new Employee()
            {
                Address = new List<Address>() { new Address { City = "op", Street = "thatstreet", Zip = 23312 } },
                Age = 23,
                EmpId = "Emp1",
                Name = "SteveIsTheName"
            };


        Employee Carol = new Employee()
            {
                Address = new List<Address>() {
                    new Address { City = "op2", Street = "thatstreet2", Zip = 23313 },
                    new Address { City = "op3", Street = "thatstreet3", Zip = 23314 }},
                Age = 24,
                EmpId = "Emp2",
                Name = "CarolIsTheName"
            };

        myEmployees.Add(Steve);
        myEmployees.Add(Carol);

        return myEmployees;
    }

Шаг 1: Определите иерархическое представление сетки:

protected void RadGrid1_Init(object sender, EventArgs e)
{
    DefineGridStructure();
}

private void DefineGridStructure()
{
    RadGrid1.MasterTableView.DataKeyNames = new string[] { "EmpId" };
    RadGrid1.Width = Unit.Percentage(98);
    RadGrid1.PageSize = 3;
    RadGrid1.AllowPaging = true;
    RadGrid1.AllowSorting = true;
    RadGrid1.PagerStyle.Mode = GridPagerMode.NextPrevAndNumeric;
    RadGrid1.AutoGenerateColumns = false;
    RadGrid1.ShowStatusBar = true;

    RadGrid1.MasterTableView.PageSize = 3;

    //Add columns
    GridBoundColumn boundColumn;
    boundColumn = new GridBoundColumn();
    boundColumn.DataField = "EmpId";
    boundColumn.HeaderText = "EmpId";
    RadGrid1.MasterTableView.Columns.Add(boundColumn);
    boundColumn = new GridBoundColumn();
    boundColumn.DataField = "Name";
    boundColumn.HeaderText = "Name";
    RadGrid1.MasterTableView.Columns.Add(boundColumn);
    boundColumn = new GridBoundColumn();
    boundColumn.DataField = "Age";
    boundColumn.HeaderText = "Age";
    RadGrid1.MasterTableView.Columns.Add(boundColumn);

    //Detail table - Orders (II in hierarchy level)
    GridTableView tableViewOrders = new GridTableView(RadGrid1);
    tableViewOrders.Width = Unit.Percentage(100);
    tableViewOrders.DataKeyNames = new string[] { "EmpId" };

    GridRelationFields relationFields = new GridRelationFields();
    relationFields.MasterKeyField = "EmpId";
    relationFields.DetailKeyField = "EmpId";
    tableViewOrders.ParentTableRelation.Add(relationFields);
    RadGrid1.MasterTableView.DetailTables.Add(tableViewOrders);

    //Add columns
    boundColumn = new GridBoundColumn();
    boundColumn.DataField = "Street";
    boundColumn.HeaderText = "Street";
    tableViewOrders.Columns.Add(boundColumn);

    boundColumn = new GridBoundColumn();
    boundColumn.DataField = "City";
    boundColumn.HeaderText = "City";
    tableViewOrders.Columns.Add(boundColumn);
    boundColumn = new GridBoundColumn();
    boundColumn.DataField = "Zip";
    boundColumn.HeaderText = "Zip";
    tableViewOrders.Columns.Add(boundColumn);
}

Шаг 2: Установите источники данных: (Нет необходимости вызывать метод DataBind или добавлять отношения, это делаетсясетка)

    protected void RadGrid1_NeedDataSource(object sender, GridNeedDataSourceEventArgs e)
    {
        List<Employee> empList = GetEmployeeDetails();

        DataSet dataset = new DataSet("DataSet");

        System.Data.DataTable dt1 = new System.Data.DataTable();
        dt1.TableName = "Employee";
        dt1.Columns.Add("EmpId");
        dt1.Columns.Add("Name");
        dt1.Columns.Add("Age");
        dataset.Tables.Add(dt1);

        System.Data.DataTable dt2 = new System.Data.DataTable();
        dt2.TableName = "Address";
        dt2.Columns.Add("EmpId");
        dt2.Columns.Add("Street");
        dt2.Columns.Add("City");
        dt2.Columns.Add("Zip");
        dataset.Tables.Add(dt2);

        foreach (Employee emp in empList)
        {
            dt1.Rows.Add(new object[] { emp.EmpId, emp.Name, emp.Age });
            foreach (Address add in emp.Address)
            {
                dt2.Rows.Add(new object[] { emp.EmpId, add.Street, add.City, add.Zip });
            }
        }

        RadGrid1.MasterTableView.DataSource = dataset.Tables["Employee"];
        RadGrid1.MasterTableView.DetailTables[0].DataSource = dataset.Tables["Address"];

    }

Шаг 3: Запустите его.

Очевидно, вам может потребоваться внести коррективы в ваш регистр, поскольку могут быть небольшие различия в капитализации.Я также настроил ваши классы, чтобы разрешить установку переменных данных, ничего большого:

class Employee
{
    public List<Address> Address { get; set; }

    public int Age { get; set; }

    public string Name { get; set; }

    public string EmpId { get; set; }
}

class Address
{
    public string Street { get; set; }

    public string City { get; set; }

    public int Zip { get; set; }
}

Надеюсь, это поможет.

-JJ

...