今天一位同事咨詢Devexpress TreeList控制項綁定自動顯示父子節點對像,但結果是不會顯示帶父子節點關係,而是將所有的節點作為父節點顯示出來了,對像類的代碼如下 public class Item:XPBaseObject { public Item() : base() { } publ
今天一位同事咨詢Devexpress TreeList控制項綁定自動顯示父子節點對像,但結果是不會顯示帶父子節點關係,而是將所有的節點作為父節點顯示出來了,對像類的代碼如下
public class Item:XPBaseObject { public Item() : base() { } public Item(Session session) : base(session) { } [Key(true)] public int Id{ get;set; } public string Name{get;set;} [Association("SubItems"),Persistent("ParentId")] public Item ParentItem; [Association("SubItems", typeof(Item)), Aggregated] public XPCollection<Item> SubItems { get { return GetCollection<Item>("SubItems"); } } }
1 //...省略部分 2 3 this.treeList1.KeyFieldName = "Id"; 4 this.treeList1.Name = "treeList1"; 5 this.treeList1.ParentFieldName = "ParentId"; 6 7 //...省略部分
實際XPO在資料庫中自動生成的數據結構也是符合我們設計的要求的,填寫的數據什麼地都是正確的,但結果就是不會按照父子節點關係來顯示。最後在之前的代碼中找到不一樣的地方,就是this.treeList1.ParentFieldName = "ParentId"; 這裡的欄位名在對像類中沒有顯示聲明一個屬性導致,雖然在屬性ParentItem里有指定欄位名ParentId但這裡僅僅用於將外鍵關係存入ParentId這個欄位而已。TreeList控制項並不會智能地讀取該值作為父節點的主鍵值,還是得要在對像類中聲明一個只讀的ParentId屬性才能解決這個問題,見下麵的代碼:
1 public class Item:XPBaseObject 2 { 3 4 //...省略 5 6 7 [NonPersistent] 8 public int ParentId 9 { 10 get { return ParentItem == null ? 0 : this.ParentItem.Id; } 11 } 12 13 14 //...省略 15 16 17 }
總結:TreeList 控制項中綁定的欄位都是需要在對像類中要存在的屬性才可以綁定,不能光在資料庫中存在欄位就可以,如果屬性不存在可以寫一個只讀並且不用存入資料庫的屬生用於綁定專用。