澳门新葡萄京娱乐网站-澳门新葡萄京888官网-所有平台

热门关键词: 澳门新葡萄京娱乐网站,澳门新葡萄京888官网

JS对象与json字符串格式,自个儿计算的

作者: 编程知识  发布:2019-12-11

率先种:利用MODEL拼成要出口JSON的指标。再用JSON.NET转成JSON输出到前端(这种常用,就不譬喻了。)

  本文目的在于介绍借使由此C#将拿到到的XML文书档案转变来对应的JSON格式字符串,然后将其出口到页前边端,以供JavaScript代码剖判接受。可能你能够一向运用JavaScript代码通过Ajax的措施来读取XML,然后直接对里面包车型地铁原委张开分析,这样大概更直接一些。但本文中提交的代码目的在于认证如何通过原生的C#代码来成功那黄金年代转移。除外,你依然能够借用一些第三方类库或许更加尖端部分的.NET库对象来实施转变。大家来探视这里介绍的一些较为简单的不二秘技,但前提是您一定要具备可帮忙的类库和对象以备使用。

图片 1图片 2

第三种:利用table拼成JSON数据格式,再用JSON.NET转成JSON输出到前端:

  • 使用Json.NET类库
 1 <head>
 2     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 3     <title></title>
 4     <script type="text/javascript">
 5         var obj = new Object();
 6         obj.Name = "八戒"
 7         obj.Age = 500;
 8 
 9         //通过字面量的形式来定义对象
10         var obj1 = { "Name": "八戒", "Age": "500" };
11         var arr = [{ "Name": "八戒", "Age": "500" }, { "Name": "八戒1", "Age": "1000" }];
12 
13         //JSON格式:将json的字面量表示形式,当做字符串存放,则为json格式字符串
14         var str = '{ "Name": "八戒", "Age": "500" }';
15         var jsonstrarr = '[{ "Name": "八戒", "Age": "500" }, { "Name": "八戒1", "Age": "1000" }];';
16         
17         //将json字符串转换成js对象(数组)
18         var resobj = JSON.parse(str);
19         alert(resobj.Name);
20 
21     </script>
22 </head>
23 <body>
24 </body>
25 </html>

          

  前提是急需首先下载和安装Json.NET类库,在那间能够找到

jsobAndJson

  dt = new DataTable();

            dt.Columns.Add(new DataColumn("列头",typeof(string)));
            dt.Columns.Add(new DataColumn("object", typeof(object)));

            DataRow dr = dt.NewRow();
            dr[0] = "abc";

            DataTable dt2 = dt.Clone();
            dt2.Columns.Add("defaultdata", typeof(string));
            DataRow dr2 = dt2.NewRow();
            dr2[0] = "defgijk";
            dr2["defaultdata"] = "cccc";
            dt2.Rows.Add(dr2);

            dr[1] = dt2;

            dt.Rows.Add(dr);

            GridView1.DataSource = dt.Rows[0][1];
            GridView1.DataBind();

            Label1.Text = JsonConvert.SerializeObject(dt);

  上边是二个事例:

 在前端js对象和json对象的互转:

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using Newtonsoft.Json;

namespace JSonConverter
{
    class Program
    {
        static void Main(string[] args)
        {
            string xml = "<Test><Name>Test class</Name><X>100</X><Y>200</Y></Test>";

            XmlDocument doc = new XmlDocument();
            doc.LoadXml(xml);
            string json = Newtonsoft.Json.JsonConvert.SerializeXmlNode(doc);

            Console.WriteLine("XML -> JSON: {0}", json);
            Console.ReadLine();

        }
    }
}

大器晚成、JS对象转变到为JSON

其二种:用JSON.net自带的JOBJECT,拼成JSON格式,转成JSON在前面一个输出:

  • 使用.NET Framework中的JavaScriptSerializer.aspx)类

拍卖:引用三个json2.js文件,调用JSON.stringify(卡塔尔国方法。举例:var data = new Object(卡塔尔; var json_data = JSON.stringify(data);

    

  首先须要确定保证您的工程或服务器援救.NET 4.0或以上版本的Framework,不然不可能找到此类。

 

JObject obj = new JObject();
    obj.Add(new JProperty("Status", "S"));
    obj.Add(new JProperty("TotalCount", totalCount));
    JArray array = new JArray();
    if (result != null)
    {
    foreach (var item in result)
    {    
    array.Add(
    new JObject(
    new JProperty("X", item.X)
    , new JProperty(" XX", item.XX)
    , new JProperty("XXX", item.XXX)
    , new JProperty("Xxxxx", item.XXXX)
    , new JProperty("xxxxxxx", item.XXXXX)
    , new JProperty("xxxxxxxxx", item.XXXXXX)
    , new JProperty("xxxxxxxxxxx", item.XXXXXXX)
    , new JProperty("xxxxxxxxxxxxx", item.XXXXXXXX)
    , new JProperty("xxxxxxxxxxxxxxxxx", item.XXXXXXXXX)
    , new JProperty("xxxxxxxxxxxxxxxxxxxx", item.XXXXXXXXXX)
    , new JProperty("xxxxxxxxxxxxxxxxxxxxxxx", item.XXXXXXXXXXX)));
    }
    obj.Add(new JProperty("WorkOrderManagerList", array));
    Response.Write(JsonConvert.SerializeObject(obj));

  上边是三个事例:

PS:json2.js那几个文件在网络搜一下就能够下载到。 

 

using System;
using System.Linq;
using System.Web.Script.Serialization;
using System.Xml.Linq;

class Program
{
    static void Main()
    {
        var xml = 
        @"<Columns>
          <Column Name=""key1"" DataType=""Boolean"">True</Column>
          <Column Name=""key2"" DataType=""String"">Hello World</Column>
          <Column Name=""key3"" DataType=""Integer"">999</Column>
        </Columns>";
        var dic = XDocument
            .Parse(xml)
            .Descendants("Column")
            .ToDictionary(
                c => c.Attribute("Name").Value, 
                c => c.Value
            );
        var json = new JavaScriptSerializer().Serialize(dic);
        Console.WriteLine(json);
    }
}

二、JSON调换来为JS

 第多种:利用array数组和hashtable拼成JSON格式,转成JSON在前端输出:

  其出口结果为:{"key1":"True","key2":"Hello World","key3":"999"}

1.管理:用jQuery的叁个方法$.parseJSON(卡塔尔将JSON格式的数量转成JS对象。比如:var json_data = $.getJSON(); var data = $.parseJSON(json_data卡塔尔(قطر‎; (可用来成转变js数组)

    

  大概还有越多的方式,这里不黄金年代一列出了。那么什么样选择原生的C#代码将XML转换到JSON格式字符串呢?可能说该C#代码在超低版本的.NET Framework中也足以运营吧?来看看上边包车型地铁牵线吧。

2.将json调换来js对象的方法:var json = eval('(' + result + '卡塔尔(英语:State of Qatar)'卡塔尔; 

 ArrayList eventList = new ArrayList();

     Hashtable hx = new Hashtable();
     hx.Add("eventid", 1);
          hx.Add("eventname", "圣诞节");
       hx.Add("eventdate", "2018-08-25");
       hx.Add("eventlocation", "公司会议中心");

       for (int i = 0; i < 3; i++)
      {
      Hashtable ht = new Hashtable();
      ht.Add("eventid", i + 1);
      ht.Add("eventname", "圣诞节");
      ht.Add("eventdate", hx);
      ht.Add("eventlocation", "公司会议中心");
      eventList.Add(ht);
     }
    JavaScriptSerializer ser = new JavaScriptSerializer();
    String jsonStr = ser.Serialize(eventList);
    Response.Write(jsonStr);

Introduction

由此地方这些表明式,就完毕了将劳动器端响应给客户端的Json格式的字符串分析成了贰个Json(格式的)对象,名叫“json”,通过“json.”恐怕“json[]”的形式便可开展数量访问。

 

  JSON是三个轻量级的数据沟通格式,它能够特别轻松地被页面包车型地铁JavaScript编码为对象的形式,进而方便数据操作。

 

  基于AJAX的页面使用XmlHttpRequest指标从服务端选择数据来响应顾客的呼吁,当重临的数量是XML格式时,它能够被撤换为JSON格式的字符串进而通过JavaScript越发便于地对数码进行拍卖。

在后台对js对象和json对象的互转:

  好多应用程序都将数据存款和储蓄为XML的格式,况且会将数据以JSON的格式发送到客商端以做进一层管理。要达成这点,它们必须将XML格式调换为JSON格式。下边包车型地铁ASP.NET C#代码完成了这意气风发经过。

 

Code Description

 .NET Framework 4在System.Runtime.塞里alization中。利用JavaScriptSerializer类对数据开展类别化和反类别化

  代码中提供了一个艺术XmlToJSON,能够用来将XmlDocument对象转变为JSON字符串。代码通过迭代每三个XML节点、属性以致子节点,来成立对应的JSON对象。

栗子:

  • 代码不会变动数字和布尔类型的值
  • Xml DocumentElement对象始终会被改动为JSON对象的member:object,它信守下边那些准绳。
  • 节点的天性会被对应地改动为JSON对象的成员"attr_name":"attr_value"。如:

    XML JSON
    <xx yy='nn'></xx> { "xx" : { "yy" : "nn" } }
    <xx yy=''></xx> { "xx" : { "yy" : "" } }
  • 平昔不子节点、属性和内容的节点被改造为成员"child_name":null

    XML JSON
    <xx/> { "xx" : null }
  • 不曾参节点和总体性,不过有内容的节点被改换为成员"child_name":"child_text"

    XML JSON
    <xx>yyy</xx> { "xx" : "yyy" }
  • 此外节点和质量会被刚好地改动为"child_name":对象恐怕"child_name":[elements]对象数组,节点的值会被调换为目的成员的"value",如:

    XML JSON
    <xx yy='nn'><mm>zzz</mm></xx> { "xx" : { "yy" : "nn", "mm" : "zzz" } }
    <xx yy='nn'><mm>zzz</mm><mm>aaa</mm></xx> { "xx" : { "yy" : "nn", "mm" : [ "zzz", "aaa" ] } }
    <xx><mm>zzz</mm>some text</xx> { "xx" : { "mm" : "zzz", "value" : "some text" } }
    <xx value='yyy'>some text<mm>zzz</mm>more text</xx> { "xx" : { "mm" : "zzz", "value" : [ "yyy", "some text", "more text" ] } }
  • 字符会被哈密地转换为JSON字符串。注意该转变不会确认保证你的JavaScript代码不会受到任何注入攻击,假设中间的开始和结果来自于意气风发段不安全的XML数据源的话。上面那些事例演示了字符的转义:

    XML JSON
    <aa>/z'z''zyyy</aa> { "aa" : "/zu0027z''z\yyy" }
//将param反序列列list集合
List<ApplyPart> _ApplyPart = new JavaScriptSerializer().Deserialize<List<ApplyPart>>(param);

   在好几特殊的际遇下,譬喻下边的代码,恐怕须求您和谐对反斜线举办转义。

  

string JSON = XmlToJSON(doc);
JSON = JSON.Replace(@"", @"\");

 

  注意,在页面上运用其余未经济检察查的XML数据时都会设有安全隐患。

Example

XML输入:

<space name="Cake Collage">
<frame>
  <photo img="cakecollage1.jpg" />
  <text string="Browse my cake space" />
  <rule type="F" img="cakecollage9.jpg" x="150" y="0" w="300" h="250" />
  <rule type="F" img="cakecollage2.jpg" x="0" y="0" w="150" h="220" />
</frame>
<frame>
  <photo img="cakecollage2.jpg" />
  <rule type="B" img="cakecollage1.jpg" />
  <rule type="L" img="cakecollage3.jpg" />
</frame>
</space>

JSON输出(对代码实行了格式化):

{ "space":
  { "name": "Cake Collage",
    "frame": [ {"photo": { "img": "cakecollage1.jpg" },
                "rule": [ { "type": "F",
                            "img": "cakecollage9.jpg",
                            "x": "150",
                            "y": "0",
                            "w": "300",
                            "h": "250"
                          }, 
                          { "type": "F",
                            "img": "cakecollage2.jpg",
                            "x": "0",  
                            "y": "0",  
                            "w": "150",  
                            "h": "220" 
                          }
                        ],
                "text": { "string": "Browse my cake space" }
               },
               {"photo": { "img": "cakecollage2.jpg" },
                "rule": [ { "type": "B", "img": "cakecollage1.jpg" },
                          { "type": "L",  "img": "cakecollage3.jpg" }
                        ]
               }
             ]
  }
}

  后生可畏旦JSON字符串被定义为叁个JavaScript对象,如space_DOM,大家便可以在JavaScript代码中动用上面那么些目的和品质:

  • space_DOM.space.name
  • space_DOM.space.frame.length
  • space_DOM.space.frame[0].text.string
  • space_DOM.space.frame[0].rule[0].type

  你的JavaScript代码应该可以非常灵活地应对种种意况,如成员空中楼阁、成员只包涵value、或成员是二个数组。上边这么些函数能够将具有的积极分子转变来二个数组,进而答应各类分化的场地。

function ObjectToArray( obj)
{
    if( !obj) return new Array();
    if( !obj.length) return new Array(obj);
    return obj;
}

space_DOM.space.frame = ObjectToArray(space_DOM.space.frame);

XmlToJSON C# code

  上边给出对应的C#源代码,通过传播的XmlDocument对象将其改动为对应的JSON格式字符串。

private static string XmlToJSON(XmlDocument xmlDoc)
{
    StringBuilder sbJSON = new StringBuilder();
    sbJSON.Append("{ ");
    XmlToJSONnode(sbJSON, xmlDoc.DocumentElement, true);
    sbJSON.Append("}");
    return sbJSON.ToString();
}

//  XmlToJSONnode:  Output an XmlElement, possibly as part of a higher array
private static void XmlToJSONnode(StringBuilder sbJSON, XmlElement node, bool showNodeName)
{
    if (showNodeName)
        sbJSON.Append(""" + SafeJSON(node.Name) + "": ");
    sbJSON.Append("{");
    // Build a sorted list of key-value pairs
    //  where   key is case-sensitive nodeName
    //          value is an ArrayList of string or XmlElement
    //  so that we know whether the nodeName is an array or not.
    SortedList childNodeNames = new SortedList();

    //  Add in all node attributes
    if( node.Attributes!=null)
        foreach (XmlAttribute attr in node.Attributes)
            StoreChildNode(childNodeNames,attr.Name,attr.InnerText);

    //  Add in all nodes
    foreach (XmlNode cnode in node.ChildNodes)
    {
        if (cnode is XmlText)
            StoreChildNode(childNodeNames, "value", cnode.InnerText);
        else if (cnode is XmlElement)
            StoreChildNode(childNodeNames, cnode.Name, cnode);
    }

    // Now output all stored info
    foreach (string childname in childNodeNames.Keys)
    {
        ArrayList alChild = (ArrayList)childNodeNames[childname];
        if (alChild.Count == 1)
            OutputNode(childname, alChild[0], sbJSON, true);
        else
        {
            sbJSON.Append(" "" + SafeJSON(childname) + "": [ ");
            foreach (object Child in alChild)
                OutputNode(childname, Child, sbJSON, false);
            sbJSON.Remove(sbJSON.Length - 2, 2);
            sbJSON.Append(" ], ");
        }
    }
    sbJSON.Remove(sbJSON.Length - 2, 2);
    sbJSON.Append(" }");
}

//  StoreChildNode: Store data associated with each nodeName
//                  so that we know whether the nodeName is an array or not.
private static void StoreChildNode(SortedList childNodeNames, string nodeName, object nodeValue)
{
    // Pre-process contraction of XmlElement-s
    if (nodeValue is XmlElement)
    {
        // Convert  <aa></aa> into "aa":null
        //          <aa>xx</aa> into "aa":"xx"
        XmlNode cnode = (XmlNode)nodeValue;
        if( cnode.Attributes.Count == 0)
        {
            XmlNodeList children = cnode.ChildNodes;
            if( children.Count==0)
                nodeValue = null;
            else if (children.Count == 1 && (children[0] is XmlText))
                nodeValue = ((XmlText)(children[0])).InnerText;
        }
    }
    // Add nodeValue to ArrayList associated with each nodeName
    // If nodeName doesn't exist then add it
    object oValuesAL = childNodeNames[nodeName];
    ArrayList ValuesAL;
    if (oValuesAL == null)
    {
        ValuesAL = new ArrayList();
        childNodeNames[nodeName] = ValuesAL;
    }
    else
        ValuesAL = (ArrayList)oValuesAL;
    ValuesAL.Add(nodeValue);
}

private static void OutputNode(string childname, object alChild, StringBuilder sbJSON, bool showNodeName)
{
    if (alChild == null)
    {
        if (showNodeName)
            sbJSON.Append(""" + SafeJSON(childname) + "": ");
        sbJSON.Append("null");
    }
    else if (alChild is string)
    {
        if (showNodeName)
            sbJSON.Append(""" + SafeJSON(childname) + "": ");
        string sChild = (string)alChild;
        sChild = sChild.Trim();
        sbJSON.Append(""" + SafeJSON(sChild) + """);
    }
    else
        XmlToJSONnode(sbJSON, (XmlElement)alChild, showNodeName);
    sbJSON.Append(", ");
}

// Make a string safe for JSON
private static string SafeJSON(string sIn)
{
    StringBuilder sbOut = new StringBuilder(sIn.Length);
    foreach (char ch in sIn)
    {
        if (Char.IsControl(ch) || ch == ''')
        {
            int ich = (int)ch;
            sbOut.Append(@"u" + ich.ToString("x4"));
            continue;
        }
        else if (ch == '"' || ch == '\' || ch == '/')
        {
            sbOut.Append('\');
        }
        sbOut.Append(ch);
    }
    return sbOut.ToString();
}

Using XmlToJSON

  上边的代码演示了什么样在ASP.NET 2的页面中利用XmlToJSON()艺术。页面上应用了ClientScriptManager对象来作为JavaScript代码的器皿。当然,你一丝一毫能够应用其余任何措施将所退换的JSON字符串放到前端页面上。通过上边包车型地铁代码,程序在前者页面上调用叁个名称为space_processJSON的JavaScript函数,并将JSON字符串作为参数字传送递给它。

protected void Page_Load(object sender, EventArgs e)
{
    XmlDocument doc = new XmlDocument();
    try
    {
        string path = Server.MapPath(".");
        doc.Load(path+"whatever.xml");
    }
    catch (Exception ex)
    {
        lblError.Text = ex.ToString();
        return;
    }

    // Convert XML to a JSON string
    string JSON = XmlToJSON(doc);

    // Replace  with \ because string is being decoded twice
    JSON = JSON.Replace(@"", @"\");

    // Insert code to process JSON at end of page
    ClientScriptManager cs = Page.ClientScript;
    cs.RegisterStartupScript(GetType(), "SpaceJSON", "space_processJSON('" + JSON + "');", true);
}

  来会见前端页面上定义的这么些JavaScript函数的具体内容。

<script src="space/json.js" type="text/javascript"></script>

<script type="text/javascript">
function space_processJSON( JSON)
{
    space_DOM = JSON.parseJSON();
    if( !space_DOM)
    {
        alert("JSON decode error");
        return;
    }
    space_DOM.space.frame = ObjectToArray(space_DOM.space.frame);
    space_frameCount = space_DOM.space.frame.length;
    //.. or whatever
}
</script>

  原来的小说出处:《How to convert XML to JSON in ASP.NET C#》

本文由澳门新葡萄京娱乐网站发布于编程知识,转载请注明出处:JS对象与json字符串格式,自个儿计算的

关键词: