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 字符串转换为对象。

  • 相关阅读:
    Android Glide详细使用教程
    mac上cocoapods安装与卸载
    Struts2+AJAX+JQuery 实现用户登入与注册功能
    Eclipse+ADT+Android SDK 搭建安卓开发环境
    CVE-2018-7600 Drupal核心远程代码执行漏洞分析
    利用kage把msf变成可视化远控平台
    在Red Hat Enterprise Linux 7.3上安装SQL Server 2017
    计算机取证之你必须要会用的24款工具
    StackStorm利用CORS null origin获得RCE (CVE-2019-9580)
    iOS/OSX漏洞分析和再现:CVE-2019-7286
  • 原文地址:https://www.cnblogs.com/suanai/p/14255545.html
Copyright © 2011-2022 走看看