使用自定义对象的分层数据(telerik RadGridView)

时间:2011-02-17 02:28:26

标签: c# winforms telerik radgridview

假设我有

class Person
{
    public int Id {get;set;}
    public string Name {get;set;}
    public List<Person> All {get;set;}

    public Person()
    {
    }

    public List<Person> GetAll()
    {
        //fills the list with person and returns
    }
}

我有:

class Address 
{
    public int PersonId {get;set;}
    public string theAddress {get;set;}
    public List<Address> All {get;set;}

    //constructor, etc

    public List<Address> GetAll()
    {
        //fills the address list and returns
    }
}

我想要做的就是以下内容:

//filling the maintemplate with data
radGridView1.DataMember = "Person";
radGridView1.DataSource = new Person().GetAll();     

//address template, the child one
GridViewTemplate template = new GridViewTemplate();
template.DataSource = new Address().GetAll();
template.DataMember = "Address";
radGridView1.MasterTemplate.Templates.Add(template);

//now the relation between those 2 classes

GridViewRelation relation = new GridViewRelation(radGridView1.MasterTemplate);
relation.ChildTemplate = template;
relation.RelationName = "PersonAddress"; //just a name
relation.ParentColumnNames.Add("Id"); //field to be "joined" to create the relation
relation.ChildColumnNames.Add("PersonId"); //same as above
radGridView1.Relations.Add(relation);

我得到的只是一个gridview,每个Person旁边都有一个“+”符号 问题是,“子”网格是EMPTY,如果我尝试添加数据(默认情况下,它允许在类中使用空构造函数),我抛出一个NullArgumentException

有什么想法吗?我几乎放弃了。我的问题是:我在所有项目中使用自定义对象,它不像“你使用数据集,它准备好使用等”,我知道,但我想知道是否有办法使用CUSTOM OBJECTS,或者如果我完成并应尝试数据集...

谢谢你们

2 个答案:

答案 0 :(得分:4)

看起来您正在使用WinForms实现。如果那是对的,那么这对我很有用。请放手一搏

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using Telerik.WinControls.UI;

namespace RadGridView_Hierarchy_CS
{
    public partial class Form1 : Form
    {

        private List<Person> people = new List<Person>();
        private List<Address> addresses = new List<Address>();

        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            FillPeople();
            FillAddresses();

            radGridView1.DataSource = people;

            GridViewTemplate template = new GridViewTemplate();
            template.DataSource = addresses;
            radGridView1.MasterTemplate.Templates.Add(template);

            GridViewRelation relation = new GridViewRelation(radGridView1.MasterTemplate);
            relation.ChildTemplate = template;
            relation.RelationName = "PersonAddress";
            relation.ParentColumnNames.Add("Id");
            relation.ChildColumnNames.Add("PersonId");
            radGridView1.Relations.Add(relation);

        }

        private void FillPeople()
        {
            Person richard = new Person();
            richard.Name = "Richard";
            richard.Id = 1;
            people.Add(richard);
            Person bob = new Person();
            bob.Name = "Bob";
            bob.Id = 2;
            people.Add(richard);
            Person mike = new Person();
            mike.Name = "Mike";
            mike.Id = 3;
            people.Add(mike);
        }

        private void FillAddresses()
        {
            Address house1 = new Address();
            house1.PersonId = 1;
            house1.Id = 1;
            house1.theAddress = "1 The Mews";
            addresses.Add(house1);
            Address house2 = new Address();
            house2.PersonId = 2;
            house2.Id = 2;
            house2.theAddress = "2 The Mews";
            addresses.Add(house2);
        }    
    }

    class Person 
    {     
        public int Id {get;set;}     
        public string Name {get;set;}     


        public Person()     
        { 
        }              
    }

    class Address  
    {
        public int Id { get; set; }   
        public int PersonId {get;set;}    
        public string theAddress {get;set;}     

        public Address()
        { 
        }
    }
}

答案 1 :(得分:2)

在搜索解决方案时偶然发现了你的帖子,所以如果有人需要的话,请添加我的解决方案......(使用2011年第一季度版本)。

在您的UC / Grid的某些初始化方法中,您可以执行类似

的操作
     //setup the template 
     GridViewTemplate subtemplate = new GridViewTemplate();
     subtemplate.AutoSizeColumnsMode = GridViewAutoSizeColumnsMode.Fill;
     subtemplate.EnableFiltering = false;
     subtemplate.EnableGrouping = false;
     subtemplate.AutoGenerateColumns = false;

     //define / add the cols
     GridViewTextBoxColumn atextcol = new GridViewTextBoxColumn("Name");
     //further properties of atextcol

      //add the cols to the template
      subtemplate.Columns.Add(atextcol);

      //add the template to the grid
      thegrid.Templates.Add(subtemplate);

     //add a HierarchyDataProvider && subscribe to the RowSourceNeeded-Event
      subtemplate.HierarchyDataProvider = new GridViewEventDataProvider(subtemplate);

      thegrid.RowSourceNeeded += new GridViewRowSourceNeededEventHandler(thegrid_RowSourceNeeded);

然后,在eventhandler中填充行/行

protected void thegrid_RowSourceNeeded(object sender, GridViewRowSourceNeededEventArgs e)
        {
            e.Template.Rows.Clear();
            patentdata cparent = e.ParentRow.DataBoundItem as patentdata;

            foreach (subdataobject sub in parentdata.subs)
            {
                GridViewRowInfo row = e.Template.Rows.NewRow();
                row.Tag = sub;
                row.Cells["Name"].Value = sub.Name;
                e.SourceCollection.Add(row);
            }
        }

所以,就是这样。评论家?