zoukankan      html  css  js  c++  java
  • Json数据解析

    一、说在前面

    在web开发的过程中经常遇到后台需要格式化返回数据到界面上,界面进行显示,而数据传递的中间格式往往是json,本篇博客旨在总结一下json格式数据在包装和解析时的一些方法。

    二、内容

    (1)eval()函数

    var dataObj=eval("("+data+")");

    加()原因在于:eval本身的问题。 由于json是以”{}”的方式来开始以及结束的,在JS中,它会被当成一个语句块来处理,所以必须强制性的将它转换成一种表达式。

    加上圆括号的目的是迫使eval函数在处理JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行。举一个例子,例如对象自变量{},如若不加外层的括号,那么eval会将大括号识别为JavaScript代码块的开始和结束标记,那么{}将会被认为是执行了一句空语句。所以下面两个执行结果是不同的:

    alert(eval("{}"); // return undefined

    alert(eval("({})");// return object[Object]

    (2)jquery自带的方法解析 jQuery.parseJSON(json)

     

    $(function () { 
        var obj = jQuery.parseJSON('{"name":"John"}');
        alert( obj.name === "John" );
    })

    parseJSON() 函数用于将符合标准格式的的JSON字符串转为与之对应的JavaScript对象。

    (3)利用$.getJSON()方法获得服务器返回

    $(document).ready(function(){
        $("button").click(function(){
            $.getJSON("demo_ajax_json.js",function(result){
                $.each(result, function(i, field){
                    $("div").append(field + " ");
                });
            });
        });
    });

    getJSON() 方法使用 AJAX 的 HTTP GET 请求获取 JSON 数据。其语法为:$(selector).getJSON(url,data,success(data,status,xhr))

    (4)JSON.parse()源生方法

    JSON.parse(text[, reviver])

    JSON.parse()源生方法用于将一个 JSON 字符串转换为对象。

  • 相关阅读:
    字节流、字符流
    ArrayList、LinkedList、Vector 的区别。
    Java 为每个原始类型提供了哪些包装类型:
    int 和 Integer 有什么区别
    怎样自动把报表插入到 word 文档中
    web 报表中电子图章 / 水印的轻松实现
    玩转报表排名
    报表设计技巧之隔行异色
    单据类报表的制作
    轻松 get 报表模糊查询技能
  • 原文地址:https://www.cnblogs.com/suanai/p/14255545.html
Copyright © 2011-2022 走看看