动态树控制

Dynamic tree control

本文关键字:控制 动态      更新时间:2023-09-26

我正在使用 http://www.jeasyui.com 中名为"树"的控件。但就我而言,我想首先在最高级别加载,然后当单击其中一个节点加载时,它是子节点。

<ul id="tt" checkbox="true" animate="true"></ul>
  $(function() {
        $('#tt').tree({
                data: @Html.Raw(Model.Tree)
            });
    });

在这个函数上,我从数据库中获取所选节点的子节点:

$(function() {
        $('#tt').tree({
                onBeforeExpand: function(node) {
                    var hospitalId = node.id;
            $.getJSON('@Url.Action("LoadDepartments")', { hospitalId: hospitalId }, function () {
                });
                }});});
  [HttpGet]
        public ActionResult LoadDepartments(Guid hospitalId)
        {
            LoadHospitals();
            var departments = _templateAccessor.GetDepartments(hospitalId);
            var hospital = tree.Where(obj => obj.id == hospitalId.ToString()).FirstOrDefault();
            if (hospital != null)
            {
                foreach (var department in departments)
                {
                    DataTreeModel dep = new DataTreeModel();
                    dep.id = department.Id.ToString();
                    dep.text = department.Name;
                    dep.state = "closed";
                    hospital.children.Add(dep);
                    hospital.state = "open";
                }
            }
              var result = SerializeToJsonString(tree);
        return Json(result, JsonRequestBehavior.AllowGet);
        }

在方法加载部门中,我有正确的结构,但树没有显示新元素。 问题是如何清理树的先前内容并用新内容填充它,也许我做错了什么?

jqTree

此树应该具有您需要的功能,它非常轻巧且易于使用。我不是在做广告,但几周前我遇到了同样的情况,这为我提供了一个解决方案。它还将跟踪打开的节点等...