zoukankan      html  css  js  c++  java
  • json字符串、json对象、数组之间的转换

    复制代码

        json字符串转化成json对象
        
    // jquery的方法
    var jsonObj = $.parseJSON(jsonStr)
    //js 的方法
    var jsonObj =  JSON.parse(jsonStr)
    
        json对象转化成json字符串 
    //js方法
    var jsonStr1 = JSON.stringify(jsonObj)
    
     
    
    json对象和json字符串之间的相互转换 
    
    例一:比如我有两个变量,我要将a转换成字符串,将b转换成JSON对象:
    
    var a={"name":"tom","sex":"男","age":"24"};
    
    var b={"name":"Mike","sex":"女","age":"29"};
    
    在Firefox,chrome,opera,safari,ie9,ie8等高级浏览器直接可以用JSON对象的stringify()和parse()方法。
    
    JSON.stringify(obj)将JSON转为字符串。JSON.parse(string)将字符串转为JSON格式;
    
    上面的转换可以这么写:
        
    var a={"name":"tom","sex":"男","age":"24"};
     
    var b={"name":"Mike","sex":"女","age":"29"};
     
    var aToStr=JSON.stringify(a);
     
    var bToObj=JSON.parse(b);
     
    alert(typeof(aToStr));  //string
     
    alert(typeof(bToObj)); //object
    
    JSON.stringify()
    
    ie8(兼容模式),ie7和ie6没有JSON对象,不过http://www.json.org/提供了一个json.js,这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;
    
    你可以在https://github.com/douglascrockford/JSON-js上获取到这个js,一般现在用json2.js。
    
    ie8(兼容模式),ie7和ie6可以使用eval()将字符串转为JSON对象,
    
    var c={"name":"Mike","sex":"女","age":"29"};
     
    var cToObj=eval("("+c+")");
     
    alert(typeof(cToObj));
    
    JQuery中也有将字符串转为JSON格式的方法jQuery.parseJSON( json ),接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)对象。
    
    当然如果有兴趣可以自己封装一个jQuery扩展,jQuery.stringifyJSON(obj)将JSON转为字符串。
    
     
    
    例二:
        
    <script type="text/javascript">
            var jsonStr = '[{"id":"01","open":false,"pId":"0","name":"A部门"},{"id":"01","open":false,"pId":"0","name":"A部门"},{"id":"011","open":false,"pId":"01","name":"A部门"},<br>{"id":"03","open":false,"pId":"0","name":"A部门"},{"id":"04","open":false,"pId":"0","name":"A部门"}, {"id":"05","open":false,"pId":"0","name":"A部门"}, {"id":"06","open":false,"pId":"0","name":"A部门"}]';
          //  var jsonObj = $.parseJSON(jsonStr);
          var jsonObj =  JSON.parse(jsonStr)
            console.log(jsonObj)
         var jsonStr1 = JSON.stringify(jsonObj)
         console.log(jsonStr1+"jsonStr1")
     </script>
    
     
    
        json对象转化成数组 
    <script type="text/javascript">
            var jsonStr = '[{"id":"01","open":false,"pId":"0","name":"A部门"},{"id":"01","open":false,"pId":"0","name":"A部门"},{"id":"011","open":false,"pId":"01","name":"A部门"},<br>{"id":"03","open":false,"pId":"0","name":"A部门"},{"id":"04","open":false,"pId":"0","name":"A部门"}, {"id":"05","open":false,"pId":"0","name":"A部门"}, {"id":"06","open":false,"pId":"0","name":"A部门"}]';
          //  var jsonObj = $.parseJSON(jsonStr);
          var jsonObj =  JSON.parse(jsonStr)
            console.log(jsonObj)
         var jsonStr1 = JSON.stringify(jsonObj)
         console.log(jsonStr1+"jsonStr1")
         var jsonArr = [];
         for(var i =0 ;i < jsonObj.length;i++){
                jsonArr[i] = jsonObj[i];
         }
         console.log(typeof(jsonArr))
     </script>
    复制代码
  • 相关阅读:
    djongo 前端页面展示自定义api返回的列表数据,并拼接到table上
    ou are trying to add a non-nullable field 'address' to person without a default; we can't do that (the database needs something to populate existing rows).
    python string 类型的公钥转换类型并解密
    Django 禁止访问403,CSRF验证失败,相应中断
    springboot async
    此博客可能不再更新,往后博文将发布在 GitHub 中
    css 中 transition 需要注意的问题
    学习笔记(九)
    微信小程序 drawImage 问题
    学习笔记(八)
  • 原文地址:https://www.cnblogs.com/BluceLee/p/json.html
Copyright © 2011-2022 走看看