0

我正在使用 MVC4 和 C#。我有一个 KendoUI Treeview,我想用来自 RavenDB 的数据填充它。

在演示中,他们使用了这个:

public JsonResult Employees(int? id)
    {
        var dataContext = new NorthwindDataContext();

        var employees = from e in dataContext.Employees
                        where (id.HasValue ? e.ReportsTo == id : e.ReportsTo == null)
                        select new {
                            id = e.EmployeeID,
                            Name = e.FirstName + " " + e.LastName,
                            hasChildren = e.Employees.Any()
                        };

        return Json(employees, JsonRequestBehavior.AllowGet);
}

注意参数“id”——它是一个整数。在 RavenDb 中,文档 ID 是字符串,例如。myDco/231...

想象这是一个标准文档:

{
  "CreationDate": "12/12/2012 8:07:59 PM",
  "Name": "jkljklk",
  "Type": "kljkljkljkljkl",
  "Description": "ljkljklj",
  "CreatedByUser": "ljklklkljklj",
  "Deleted": false,
  "Status": "NEW",
  "Parent": "product/546"
}

我将如何填充树视图?

4

2 回答 2

1

使用 string 而不是 int 应该没有任何问题。您只需要根据传递给 Action 方法的字符串参数来获取所需的记录。

于 2012-12-12T21:01:30.737 回答
1

我想通了。

我更改了我的 RavenDB 文档以包含其所有子项的列表:

{
  "CreationDate": "12/12/2012 9:33:34 PM",
  "Name": "hohoho",
  "Type": "hohohoh",
  "Description": "hohohoh",
  "CreatedByUser": "hohohoh",
  "Deleted": false,
  "Status": "NEW",
  "Parent": "ohohohoh",
  "Children": [
  "item/1",
  "item/2",
  "item/3"
  ]
}

然后我通过控制器将我的项目列表返回给视图,然后遍历它们,将所有子节点附加到它们正确的父节点:

@(Html.Kendo().TreeView().Name("TreeView").DragAndDrop(true)
.Items(treeview =>
           {
               foreach (var myItem in Model)
               {
                   var myItemName = myItem.Name;
                   var children = myItem.Children;
                   treeview.Add().Text(myItemName ).Expanded(false).Items(branch =>
                                                                             {
                                                                                  if (children != null)
                                                                                     {
                                                                                         foreach (var child in children)
                                                                                         {
                                                                                             branch.Add().Text(child);
                                                                                         }
                                                                                     }
                                                                             });
               }
           }
   ))

无论如何,感谢您的回复:)

希望有一天这对其他人有所帮助。

于 2012-12-14T13:53:21.433 回答