2016-12-01 9 views
0

Это TreeView Кендо я использую, чтобы связатьКак я могу назвать древовидное дерево Kendo (тип привязки данных сервера) после успешной публикации сообщения AJAX?

Html.Kendo().TreeView() 
       .Name("TreeViewTemplateBiding") 
       .Events(events => events 
      .Select("onSelect")) 
         .BindTo((IEnumerable<OrgChart.Models.NodeViewModel>)ViewBag.Tree, (Kendo.Mvc.UI.Fluent.NavigationBindingFactory<TreeViewItem> mappings) => 
          { 
           mappings.For<OrgChart.Models.NodeViewModel>(binding => binding.ItemDataBound((item, node) => 
           { 
            item.Id = node.Id; 
            item.Text = node.Title; 
            //item.Url = "/Organizational/Chart/" + node.Id; 
            //item.Expanded = node.Expanded; 
           }) 
         .Children(node => node.Children)); 
          }) 
    ) 

И AJAX пост используется для получения данных onselect узла и отправки его на контроллер, чтобы получить своих детей.

<script> 
function onSelect(e) { 
    alert("hi"); 
    var data = this.text(e.node); 
    alert(data); 
    var a = data.split("- ").pop(); 
    alert(a); 
    $.ajax({ 
     url: '@Url.Action("Chart", "Organizational")', 
     type: 'Post', 
     dataType: 'json', 
     data: { a : a }, 
     async: true, 
     cache: false, 
     success: function (data) { 
      alert("sending"); 
      process(data); 
     }, 
     error: function (data) { } 
    }); 
    $(document).ready(function() { 
     treeview = $("#treeview").data("kendoTreeView"); 
    }); 
} 
</script> 

Поэтому после успешной публикации мне нужно снова позвонить в дерево Кендо.

+0

Возможно, вы можете сэкономить время, используя HierarchicalDataSource здесь, если все ваши узлы имеют уникальный идентификатор. –

+0

Этот HierarchicalDataSource в TreeView сделает обратный вызов конечной точке, чтобы получить дочерние элементы для выбранного узла, если он не загружен. –

+0

ОК, как я могу это достичь, PLZ помогите мне с этим – Bharath

ответ

0

Это не точный ответ, однако это один из способов дать вам HierarchicalDataSource.

ПРИМЕЧАНИЕ: Это псевдокод. Нет проверки типа проверки и разбиения ввода для получения nodetype/nodeid.

Простой TreeView Класс

public class TreeViewItem 
    { 
     //Collection item returned in he Hierarchical search 
     public TreeViewItem() 
     { 
      CanSelect = true; 
     } 

     public string NodeID{get;set;} 
     public string NodeText{ get; set; }   
     public bool HasChildren { get; set; } 
     public bool CanSelect { get; set; } 
     public string NodeImage { get; set; } 
    } 

Контроллер

//------------------------------------------------------------------------------------------------------ 
[OutputCache(NoStore = true, Duration = 0)] 
public ActionResult PerformHierarchicalSearch(string NodeID) 
{ 
    //This action returns the data as List<TreeViewItem> in json format to the browse view. 
    //The view is configured as three treeviews that use the Kendo Hierarchical datasource 
    //Requires a NodeID and HasChildren each time an item is expanded it returns a NodeID 
    //On the intial load NodeID is null so return all items for the root 

    //When a treeview item is expanded it calls this action but this time the node ID will be in <ENTITY_ID>:<USER_TYPE> format ex: 10038:40 
    //We split that out and determine what to load. For example all children of a selected parent. 

    string[] kludge = NodeID.Split(':'); 
    int nodeID = Convert.ToInt32(kludge[0]); 
    int nodeType = Convert.ToInt32(kludge[1]); 

    List<TreeViewItem> items = new List<TreeViewItem>(); 

    switch (nodeType) 
    { 
     case 1: 
      List<Type1> type1List = new Type1Controller().GetType1(nodeID).ToList(); 
      foreach (Type1 type1 in type1List) 
       items.Add(new TreeViewItem 
       { 
        NodeID = type1.TypeID.ToString() + ":1", 
        NodeText = type1.TypeName, 
        HasChildren = true, 
        NodeImage = "TYPE1" 
       }); 
      break; 
     case 2: 
      List<Type2> type1List = new Type2Controller().GetType2(nodeID).ToList(); 
      foreach (Type2 type1 in type2List) 
       items.Add(new TreeViewItem 
       { 
        NodeID = type2.TypeID.ToString() + ":2", 
        NodeText = type2.TypeName, 
        HasChildren = true, 
        NodeImage = "TYPE2" 
       }); 
      break; 
    } 
    if (items.Count == 0) 
     items.Add(new TreeViewItem { NodeID = Guid.NewGuid().ToString(), NodeText = "No Data", HasChildren = false, CanSelect = false, NodeImage = "" }); 

    return Json(items, JsonRequestBehavior.AllowGet); 
} 
} 

Код За

<div id="treeview1" class="parentItem"></div> 

<script id="treeview-navlink" type="text/kendo-ui-template"> 
    #if (item.CanSelect != 'null' && item.CanSelect==true) { # 
     <img src='@Url.Content("~/Images/Icons/16/Soft/")#: item.NodeImage #.png'+ alt='#: item.NodeImage #'/> <a href='\#' id= '#: item.NodeID #' class='entity-link' >#: item.NodeText #</a>  
    #}else{# 
     <span class='dimText'>#: item.NodeText #</span>  
    #}# 
</script> 



<script type="text/javascript"> 

    var treeLoaded = false; 

    ds1 = new kendo.data.HierarchicalDataSource({ 
     transport: { 
      read: { 
       url: '@Url.Action("PerformHierarchicalSearch","Search")' , 
       dataType: "json", 
       data: addData1 
      } 
     }, 
     schema: { 
      model: { 
       id: "NodeID", 
       hasChildren: "HasChildren" 
      } 
     } 
    }); 

    function addData1(d) { 
     var treeview = $('#treeview1').data('kendoTreeView'); 
     if (treeLoaded === true) 
      return { NodeID: d.NodeID}; 
     treeLoaded = true; 
     return { }; 
    } 


    $(document).ready(function() { 

     $("#treeview1").kendoTreeView({ 
      dataSource: ds1, 
      dataTextField: "NodeText", 
      template: kendo.template($("#treeview-navlink").html()) 
     }); 
    }); 

</script>