2011-05-21 2 views
0

Привет всем,загрузка JS дерево из JSON в ASP.Net 3.5 и MVC 2.0

я пытаюсь написать небольшой пример, чтобы создать дерево с помощью Jstree & запроса (новая версия обязывает) в ASP.Net 3.5 & MVC 2.0. Я должен сделать это в этих технологиях.

Когда я пытаюсь загрузить данные в формате JSON, дерево не загружается. Он просто показывает диалоговое окно java-скрипта (ошибка/неизвестно) и отображает «Загрузка ...». Это оно.

Не могли бы вы помочь мне разобраться с полным решением?

Если у вас есть рабочее решение в MVC & JSON для загрузки дерева с помощью json, jquery, jstree с добавлением/удалением/переименованием/созданием функциональности для справки, пожалуйста, поделитесь им.

Код: Мои index.aspx Вид:

<%@ Page Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage" %> 

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server"> 
    Home Page 
</asp:Content> 

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server"> 
    <h2><%= Html.Encode(ViewData["Message"]) %></h2> 
    <p> 
     To learn more about ASP.NET MVC visit <a href="http://asp.net/mvc" title="ASP.NET MVC Website">http://asp.net/mvc</a>. 
    </p> 
    <script src="../../Scripts/jquery-1.6.1.min.js" type="text/javascript"></script> 
    <script src="../../Scripts/jquery.jstree.js" type="text/javascript"></script> 
    <script src="../../Scripts/MicrosoftAjax.js" type="text/javascript"></script> 
    <script type="text/javascript" language="javascript"> 
    var GetStudentsURL = '<%= Url.Action("GetTreeData", "Home")%>'; 
//alert(GetStudentsURL); 

function OnGetNodes(n) { 

    //basically, these are the parameters to be passed to the server code [they MUST match exaclty, casing and all] 
    var obj = { 
     id: n.attr ? n.attr("id") : "0" 
    } 
    return Sys.Serialization.JavaScriptSerializer.serialize(obj); 
} 

function OnNodesRetrievedSuccess(data, textstatus, xhr) { 

    //the ".d" is a security feature, annoying, but necessary 
    return Sys.Serialization.JavaScriptSerializer.deserialize(data.d); 
} 

function OnNodesRetrievedError(xhr, textstatus, errorThrown) { 
    alert(errorThrown); 

    //document.location = "/MyErrorPage.aspx?errMsg="+errorThrown; 
} 
$(function() { 
    $("#treeview").jstree({ 
     plugins: ["themes", "json_data", "checkbox", "crrm"], 
     json_data: { 
      ajax: { 
       url: GetStudentsURL, 
       async: true, 
       contentType: "application/json; charset=utf-8", 
       dataType: "text json", 
       //dataType: "text json", 
       type: "POST", 
       data: function (n) { 
       //alert(n); 
        return OnGetNodes(n); 
       }, 
       success: function (data, textstatus, xhr) { 
        //alert(data); 
        //alert(textstatus); 
        //alert(xhr); 
        return OnNodesRetrievedSuccess(data, textstatus, xhr) 
       }, 
       error: function (xhr, textstatus, errorThrown) { 
        //alert(errorThrown); 
        //alert(textstatus); 
        //alert(xhr); 
        OnNodesRetrievedError(xhr, textstatus, errorThrown) 
       } 
      } 
     } 
    }) 
}); 
    </script> 
      <div id="treeview"> 
      </div> 
</asp:Content> 

Мой HomeController»

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Web; 
using System.Web.Mvc; 
using System.Web.Script.Serialization; 
using System.Web.Script.Services; 
using jsTreeDemo.Models; 

namespace MyJSTreeDemo.Controllers 
{ 
    [HandleError] 
    public class HomeController : Controller 
    { 
     public ActionResult Index() 
     { 
      ViewData["Message"] = "TreeView Demo"; 

      return View(); 
     } 

     public ActionResult About() 
     { 
      return View(); 
     } 

     [AcceptVerbs(HttpVerbs.Post)] 
     public string GetTreeData(string id) 
     { 
      List<AjaxTreeNodeJsonObject> results = new List<AjaxTreeNodeJsonObject>(); 

      //NODE ID: TREEID_LEVEL_PARENTID_ID 

      //this should be the first call from the tree to initialize 

      if (string.IsNullOrEmpty(id) | id == "0") 
      { 
       results.Add(new AjaxTreeNodeJsonObject("TREE1_0_0_1", "U.S.A.", "#", true)); 
       results.Add(new AjaxTreeNodeJsonObject("TREE1_0_0_2", "Canada", "#", true)); 


      } 
      else 
      { 
       //Get Child Nodes 

       //these are subsequent calls to populate the tree nodes 
       string[] nodeInfo = id.Split('_'); 
       string nodeTree = nodeInfo[0]; 
       int nodeLevel = Convert.ToInt32(nodeInfo[1]); 
       int nodeParentId = Convert.ToInt32(nodeInfo[2]); 
       int nodeId = Convert.ToInt32(nodeInfo[3]); 

       //this would be better as a database lookup or some hierarchical tree structure 

       switch (nodeTree) 
       { 
        //WHICH TREE? 

        case "TREE1": 

         switch (nodeLevel) 
         { 
          //WHICH LEVEL? 

          case 0: 
           //country 

           switch (nodeParentId) 
           { 
            //WHICH PARENT? 

            case 0: 
             //no parent 

             switch (nodeId) 
             { 
              //WHICH NODE? 

              case 1: 
               //USA 

               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_1", "Alabama", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_2", "Alaska", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_3", "Arizona", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_4", "Arkansas", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_5", "California", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_6", "Colorado", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_7", "Connecticut", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_8", "Delaware", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_9", "Florida", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_10", "Georgia", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_11", "Hawaii", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_12", "Idaho", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_13", "Illinois", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_14", "Indiana", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_15", "Iowa", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_16", "Kansas", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_17", "Kentucky", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_18", "Louisiana", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_19", "Maine", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_20", "Maryland", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_21", "Massachusetts", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_22", "Michigan", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_23", "Minnesota", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_24", "Mississippi", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_25", "Missouri", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_26", "Montana", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_27", "Nebraska", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_28", "Nevada", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_29", "New Hampshire", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_30", "New Jersey", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_31", "New Mexico", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_32", "New York", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_33", "North Carolina", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_34", "North Dakota", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_35", "Ohio", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_36", "Oklahoma", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_37", "Oregon", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_38", "Pennsylvania", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_39", "Rhode Island", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_40", "South Carolina", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_41", "South Dakota", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_42", "Tennessee", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_43", "Texas", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_44", "Utah", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_45", "Vermont", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_46", "Virginia", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_47", "Washington", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_48", "West Virginia", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_49", "Wisconsin", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1_50", "Wyoming", "#")); 

               break; 
              case 2: 
               //CANDA 

               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_1", "Ontario", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_2", "Quebec", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_3", "Nova Scotia", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_4", "New Brunswick", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_5", "Manitoba", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_6", "British Columbia", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_7", "Prince Edward Island", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_8", "Saskatchewan", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_9", "Alberta", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_10", "Newfoundland and Labrador", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_11", "Northwest Territories", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_12", "Yukon", "#")); 
               results.Add(new AjaxTreeNodeJsonObject("TREE1_1_13", "Nunavut", "#")); 

               break; 
             } 

             break; 
           } 

           break; 
         } 

         break; 
       } 

      } 

      JavaScriptSerializer ser = new JavaScriptSerializer(); 

      return ser.Serialize(results); 
     } 

    } 


    internal class AjaxTreeNodeJsonObject 
    { 

     private AjaxTreeNodeJsonObjectAttribute _attr = new AjaxTreeNodeJsonObjectAttribute(); 
     private string _state = string.Empty; 
     private string _icon = string.Empty; 
     private string _metadata = string.Empty; 
     private AjaxTreeNodeJsonObjectDataLinkAttribute _data = new AjaxTreeNodeJsonObjectDataLinkAttribute(); 

     private AjaxTreeNodeJsonObject[] _children; 

     public AjaxTreeNodeJsonObjectAttribute attr 
     { 
      get { return _attr; } 
     } 

     public AjaxTreeNodeJsonObjectDataLinkAttribute data 
     { 
      get { return _data; } 
     } 

     public string state 
     { 
      get { return _state; } 
      set { _state = value; } 
     } 

     public string icon 
     { 
      get { return _icon; } 
      set { _icon = value; } 
     } 

     public string metadata 
     { 
      get { return _metadata; } 
      set { _metadata = value; } 
     } 

     public AjaxTreeNodeJsonObject[] children 
     { 
      get { return _children; } 
      set { _children = value; } 
     } 

     public AjaxTreeNodeJsonObject() 
     { 
     } 

     public AjaxTreeNodeJsonObject(string id, string title, string href) 
      : this(id, title, href, false) 
     { 
     } 


     public AjaxTreeNodeJsonObject(string id, string title, string href, bool hasChildren) 
     { 
      //li values 
      this.attr.id = id; 
      this.attr.title = title; 
      //a values 
      this.data.attr.href = href; 
      this.data.attr.id = "a" + this.attr.id; 
      this.data.title = this.attr.title; 

      if (hasChildren) 
      { 
       this.state = "closed"; 
      } 

     } 


     public AjaxTreeNodeJsonObject(string id, string title, string href, AjaxTreeNodeJsonObject[] children) 
     { 
      //li values 
      this.attr.id = id; 
      this.attr.title = title; 
      //a values 
      this.data.attr.href = href; 
      this.data.attr.id = "a" + this.attr.id; 
      this.data.title = this.attr.title; 

      if (children != null && children.Length > 0) 
      { 
       this.state = "closed"; 
       this.children = children; 
      } 

     } 

    } 

    internal class AjaxTreeNodeJsonObjectAttribute 
    { 
     private string _id = string.Empty; 

     private string _title = string.Empty; 
     /// <summary> 
     /// Gets or sets the Id value 
     /// </summary> 
     public string id 
     { 
      get { return this._id; } 
      set { this._id = value; } 
     } 

     /// <summary> 
     /// Gets or sets the Title value 
     /// </summary> 
     public string title 
     { 
      get { return this._title; } 
      set { this._title = value; } 
     } 

    } 

    internal class AjaxTreeNodeJsonObjectDataLinkAttribute 
    { 

     private string _title = string.Empty; 

     private AjaxTreeNodeJsonObjectLinkAttribute _attr = new AjaxTreeNodeJsonObjectLinkAttribute(); 
     /// <summary> 
     /// Gets or sets the Title value 
     /// </summary> 
     public string title 
     { 
      get { return this._title; } 
      set { this._title = value; } 
     } 

     public AjaxTreeNodeJsonObjectLinkAttribute attr 
     { 
      get { return _attr; } 
      set { _attr = value; } 
     } 

    } 

    internal class AjaxTreeNodeJsonObjectLinkAttribute 
    { 
     private string _id = string.Empty; 
     private string _href = string.Empty; 

     private string _target = string.Empty; 
     /// <summary> 
     /// Gets or sets the Id value 
     /// </summary> 
     public string id 
     { 
      get { return this._id; } 
      set { this._id = value; } 
     } 

     /// <summary> 
     /// Gets or sets the Href value 
     /// </summary> 
     public string href 
     { 
      get { return this._href; } 
      set { this._href = value; } 
     } 

     /// <summary> 
     /// Gets or sets the Target value 
     /// </summary> 
     public string target 
     { 
      get { return this._target; } 
      set { this._target = value; } 
     } 

    } 

    } 

Наг

ответ

1

удалить эту строку

contentType: "application/json; charset=utf-8",