• JSON实例操作


    什么是 JSON ?

    JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation)。
    JSON 是轻量级的文本数据交换格式
    JSON 独立于语言:JSON 使用 Javascript语法来描述数据对象,但是 JSON 仍然独立于语言和平台。JSON 解析器和 JSON 库支持许多不同的编程语言。 目前非常多的动态(PHP,JSP,.NET)编程语言都支持JSON。
    JSON 具有自我描述性,更易理解。

    JavaScript 程序能够使用内建的 eval() 函数,用 JSON 数据来生成原生的 JavaScript 对象。

    JSON - 简介

    <h2>JavaScript 创建 JSON 对象h2>
    <p>
    网站名称: <span id="jname">span><br /> 
    网站地址: <span id="jurl">span><br /> 
    网站 slogan: <span id="jslogan">span><br /> 
    p>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    <script>
    var JSONObject= {
        "name":"百度",
        "url":"www.baidu.com", 
        "slogan":"学的不仅是技术,更是梦想!"
    };               //  var JSONobject
    document.getElementById("jname").innerHTML=JSONObject.name 
    document.getElementById("jurl").innerHTML=JSONObject.url 
    document.getElementById("jslogan").innerHTML=JSONObject.slogan
    </script>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在这里插入图片描述

    • 使用 XML
      读取 XML 文档
      使用 XML DOM 来循环遍历文档
      读取值并存储在变量中
    • 使用 JSON
      读取 JSON 字符串
      用 eval() 处理 JSON 字符串

    JSON 语法💥

    //JSON 名称/值对
    "name" : "菜鸟教程"
    name = "菜鸟教程"
    
    //JSON 数字
    { "age":30 }
    
    //JSON 对象
    { "name":"菜鸟教程" , "url":"www.runoob.com" }
    name = "菜鸟教程"
    url = "www.runoob.com"
    
    //JSON 数组
    {
        "sites": [
            { "name":"菜鸟教程" , "url":"www.runoob.com" }, 
            { "name":"google" , "url":"www.google.com" }, 
            { "name":"微博" , "url":"www.weibo.com" }
        ]
    }
    
    //JSON 布尔值
    { "flag":true }
    { "runoob":null }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    JSON 使用 JavaScript 语法

    因为 JSON 使用 JavaScript 语法,所以无需额外的软件就能处理 JavaScript 中的 JSON。

    <h2>JavaScript 创建 JSON 对象h2>
    <p>第一个网站名称: <span id="name1">span>p> 
    <p>第一个网站修改后的名称: <span id="name2">span>p> 
    
    • 1
    • 2
    • 3
    <script>
    var sites = [
    	{ "name":"runoob" , "url":"www.runoob.com" }, 
    	{ "name":"google" , "url":"www.google.com" }, 
    	{ "name":"微博" , "url":"www.weibo.com" }
    ];
    
    document.getElementById("name1").innerHTML=sites[0].name;
    // 修改网站名称
    sites[0].name="菜鸟教程";         
    document.getElementById("name2").innerHTML=sites[0].name;       
    </script>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • JSON 文件
      JSON 文件的文件类型是 .json
      JSON 文本的 MIME 类型是 application/json

    JSON vs XML

    JSON 和 XML 都用于接收 web 服务端的数据

    {
        "sites": [
        { "name":"菜鸟教程" , "url":"www.runoob.com" }, 
        { "name":"google" , "url":"www.google.com" }, 
        { "name":"微博" , "url":"www.weibo.com" }
        ]
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    <sites>
      <site>
        <name>菜鸟教程name> <url>www.runoob.comurl>
      site>
      <site>
        <name>googlename> <url>www.google.comurl>
      site>
      <site>
        <name>微博name> <url>www.weibo.comurl>
      site>
    sites>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    最大的不同是:XML 需要使用 XML 解析器来解析,JSON 可以使用标准的 JavaScript 函数来解析。

    • JSON.parse(): 将一个 JSON 字符串转换为 JavaScript 对象。
    • JSON.stringify(): 于将 JavaScript 值转换为 JSON 字符串。

    1. 获取 JSON 字符串
    2. JSON.Parse 解析 JSON 字符串

    JSON 对象

    myObj = {
        "name":"runoob",
        "alexa":10000,
        "sites": {
            "site1":"www.runoob.com",
            "site2":"m.runoob.com",
            "site3":"c.runoob.com"
        }
    }
    //访问
    x = myObj.sites.site1;
    // 或者
    x = myObj.sites["site1"];
    
    //修改
    myObj.sites.site1 = "www.google.com";
    
    //删除
    delete myObj.sites.site1;
    delete myObj.sites["site1"]
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    JSON 数组

    {
    "name":"网站",
    "num":3,
    "sites":[ "Google", "Runoob", "Taobao" ]
    }
    
    //访问
    x = myObj.sites[0];
    //循环
    for (i in myObj.sites) {
        x += myObj.sites[i] + "
    "
    ; }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    JSON.parse()💥

    将数据转换为 JavaScript 对象

    <p id="demo">p>
    
    • 1
    <script>
    var obj = JSON.parse('{ "name":"runoob", "alexa":10000, "site":"www.runoob.com" }');
    document.getElementById("demo").innerHTML = obj.name + ":" + obj.site;
    </script>
    
    • 1
    • 2
    • 3
    • 4

    从服务端接收 JSON 数据💥

    我们可以使用 AJAX 从服务器请求 JSON 数据,并解析为 JavaScript 对象

    var xmlhttp = new XMLHttpRequest();
    xmlhttp.onreadystatechange = function() {
        if (this.readyState == 4 && this.status == 200) {
            myObj = JSON.parse(this.responseText);            //转换为js对象
            document.getElementById("demo").innerHTML = myObj.name;
        }
    };
    xmlhttp.open("GET", "/try/ajax/json_demo.txt", true);
    xmlhttp.send();
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    从服务端接收数组的 JSON 数据

    如果从服务端接收的是数组的 JSON 数据,则 JSON.parse 会将其转换为 JavaScript 数组

    var xmlhttp = new XMLHttpRequest();
    xmlhttp.onreadystatechange = function() {
        if (this.readyState == 4 && this.status == 200) {
            myArr = JSON.parse(this.responseText);
            document.getElementById("demo").innerHTML = myArr[1];
        }
    };
    xmlhttp.open("GET", "/try/ajax/json_demo_array.txt", true);
    xmlhttp.send();
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    异常

    var text = '{ "name":"Runoob", "initDate":"2013-12-14", "site":"www.runoob.com"}';
    var obj = JSON.parse(text, function (key, value) {
        if (key == "initDate") {
            return new Date(value);
        } else {
            return value;
    }});
     
    document.getElementById("demo").innerHTML = obj.name + "创建日期:" + obj.initDate;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    解析函数

    JSON 不允许包含函数,但你可以将函数作为字符串存储,之后再将字符串转换为函数。

    var text = '{ "name":"Runoob", "alexa":"function () {return 10000;}", "site":"www.runoob.com"}';
    var obj = JSON.parse(text);
    obj.alexa = eval("(" + obj.alexa + ")");
     
    document.getElementById("demo").innerHTML = obj.name + " Alexa 排名:" + obj.alexa();
    
    • 1
    • 2
    • 3
    • 4
    • 5

    JSON.stringify()💥

    在向服务器发送数据时一般是字符串。
    我们可以使用 JSON.stringify() 方法将 JavaScript 对象转换为字符串。

    <p id="demo" > p>
    
    <script>
    var obj = { "name":"runoob", "alexa":10000, "site":"www.runoob.com"};
    var myJSON = JSON.stringify(obj);
    document.getElementById("demo").innerHTML = myJSON;
    script>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    JSON 使用💥

    把 JSON 文本转换为 JavaScript 对象

    var txt = '{ "sites" : [' +
    '{ "name":"菜鸟教程" , "url":"www.runoob.com" },' +
    '{ "name":"google" , "url":"www.google.com" },' +
    '{ "name":"微博" , "url":"www.weibo.com" } ]}';
     
    var obj = eval ("(" + txt + ")");
     
    document.getElementById("name").innerHTML=obj.sites[1].name 
    document.getElementById("url").innerHTML=obj.sites[1].url
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    <h2>从 JSON 字符串中创建对象h2>
    <p>
    网站名: <span id="name">span><br> 
    网站地址: <span id="url">span><br> 
    p> 
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    JSONP 教程

    让网页从别的域名(网站)那获取资料,即跨域读取数据。
    jQuery 使用 JSONP

    如客户想访问 : https://www.runoob.com/try/ajax/jsonp.php?jsoncallback=callbackFunction。

    假设客户期望返回数据:[“customername1”,“customername2”]。

    真正返回到客户端的数据显示为: callbackFunction([“customername1”,“customername2”])。

    DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>JSONP 实例title>
        <script src="https://cdn.static.runoob.com/libs/jquery/1.8.3/jquery.js">script>    
    head>
    <body>
    <div id="divCustomers">div>
    <script>
    $.getJSON("https://www.runoob.com/try/ajax/jsonp.php?jsoncallback=?", function(data) {
        
        var html = '
      '; for(var i = 0; i < data.length; i++) { html += '
    • ' + data[i] + '
    • '
      ; } html += '
    '
    ; $('#divCustomers').html(html); });
    script> body> html>
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
  • 相关阅读:
    什么是测试界天花板,我今天算是见到了
    Java集训(算法&&面试题)第八天(栈与队列)
    LQ0221 逆波兰表达式【程序填空】
    混合优化算法(optimtool.hybrid)
    Cholesterol-PEG-Amine 两亲性脂质衍生物胆固醇-聚乙二醇-氨基 CLS-PEG-NH2
    java路线
    HashMap线程不安全问题以及解决方法
    Springcloudgateway如何在全局过滤器中获得请求体和响应体
    python安装 learn2learn库 || 在线安装方式或者本地安装
    Abnova丨Abnova 异种原位移殖肿瘤模型解决方案
  • 原文地址:https://blog.csdn.net/qq_44174346/article/details/126400654