Devexpress bind индексированное свойство - PullRequest
0 голосов
/ 12 декабря 2010

Мне нужно привязать индексированное свойство к элементу управления Devexpress aspxgridview. Я создаю столбцы во время выполнения и не знаю, как упомянуть эти свойства в FieldName.

Вот мой класс, который имеет обычное свойство ('p0') и 2 индексированных свойства ('p1' и 'p2'). Мне нужно связать p1 и p2 как столбец в сетке данных.

namespace TestClass{ 
    public class TestClass { 
        private int _p0; 
        private int _p1; 
        private string _p2; 
        public int p0 { get { return _p0; } set { _p0 = value; } } 
        public object this[string Field] { 
            get { switch (Field) { 
                case "p0": return _p0; 
                case "p1": return _p1; 
                case "p2": return _p2; 
                default: throw new IndexOutOfRangeException(); 
            } 
            } 
            set { 
                switch (Field) { 
                    case "p0": _p0 = (int)value; 
                        break; 
                    case "p1": _p1 = (int)value; 
                        break; 
                    case "p2": _p2 = (string)value; 
                        break; 
                    default: 
                        throw new IndexOutOfRangeException(); 
                } 
            } 
        } 
        public static TestClass[] GetABunch() { 
            TestClass[] result = new TestClass[1000]; 
            for (int i = 0; i < result.Length; i++) { 
                TestClass x = new TestClass(); 
                x["p0"] = i; 
                x["p1"] = i; 
                x["p2"] = "row " + i.ToString(); 
                result[i] = x; 
            } return result; 
        } 
    }
 }

Пример кода, который связывает объект класса

 TestClass.TestClass [] cls = TestClass.TestClass.GetABunch(); 
// This works since its a normal property. 
GridViewDataTextColumn txtCol = new GridViewDataTextColumn(); 
txtCol.FieldName = "p0"; 
grid.Columns.Add(txtCol); // Trying to bind the indexed property, not sure how to this. 
GridViewDataTextColumn txtCol1 = new GridViewDataTextColumn(); 
txtCol1.FieldName = "p1"; // should be something like MyObject["p1"] ? 
grid.Columns.Add(txtCol1); 
grid.KeyFieldName = "p0"; 
grid.DataSource = cls; 
grid.DataBind();

1 Ответ

0 голосов
/ 16 декабря 2010

Я заставил ваш код работать, объявив пару открытых свойств в классе TestClass. р1 и р2. Обратите внимание, что ASPxGridView отображает содержимое только открытых свойств бизнес-объекта. Кроме того, код для привязки сетки к источнику данных должен вызываться в методе Page_Init. Надеюсь, это поможет.

...