• JSON 表达式


    JSON语法规则:
        数据在名称/值对中;
        数据由逗号分隔;
        大括号保存对象;
        中括号保存数组
    1、访问对象值:

    1. var myObj,x;
    2. myObj = {"name":"runoob","alexa":10000,"site":null};
    3. x = myObj.name; //使用点号(.)来访问对象的值
    4. x = myObj["name"]; //使用中括号([])来访问对象的值

    2、使用for-in 来循环对象的属性:

    1. <p id="demo"></p>
    2. <script>
    3. var myObj = { "name":"runoob", "alexa":10000, "site":null };
    4. for (x in myObj) {
    5. document.getElementById("demo").innerHTML += x + "<br>";
    6. }
    7. </script>

    3、for-in循环对象的属性时,使用中括号([])来访问属性的值:

    1. <p id="demo"></p>
    2. <script>
    3. var myObj = { "name":"runoob", "alexa":10000, "site":null };
    4. for (x in myObj) {
    5. document.getElementById("demo").innerHTML += myObj[x] + "<br>";
    6. }
    7. </script>

    4、修改 JSON 对象的值: 

    myObj.sites.site1 = "www.google.com";

    5、删除 JSON 对象的属性: 

    delete myObj.sites.site1;

    5、使用索引值来访问数组:

    1. <script>
    2. var myObj, x;
    3. myObj = {"name":"网站","num":3, "sites":[ "Google", "Runoob", "Taobao" ] }
    4. x = myObj.sites[0];
    5. document.getElementById("demo").innerHTML = x;
    6. </script>

    6、使用for-in 来访问数组:

    1. <script>
    2. var myObj, i, x = "";
    3. myObj = {
    4. "name":"网站",
    5. "num":3,
    6. "sites":[ "Google", "Runoob", "Taobao" ]
    7. };
    8. for (i in myObj.sites) {
    9. x += myObj.sites[i] + "<br>";
    10. }
    11. document.getElementById("demo").innerHTML = x;
    12. </script>

    ******************************************************************************************************************************************
    1、JSON 通常用于与服务端交换数据。在接收服务器数据时一般是字符串。我们可以使用 JSON.parse() 方法将数据转换为 JavaScript 对象
    语法: JSON.parse(text,reviver)
    text:必需, 一个有效的 JSON 字符串。
    reviver: 可选,一个转换结果的函数, 将为对象的每个成员调用此函数。

    var obj  = JSON.parse('{ "name":"runoob", "alexa":10000, "site":"www.runoob.com" }');

    解析完成后,我们就可以在网页上使用 JSON 数据了:

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

    2、使用AJAX 从服务器请求 JSON 数据,并解析为 JavaScript 对象:

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

    3、 JSON.stringify()方法:
        JSON 通常用于与服务端交换数据。在向服务器发送数据时一般是字符串。我们可以使用 JSON.stringify() 方法将 JavaScript 对象转换为字符串。
    语法: JSON.stringify(value,replacer,space)
    value:必需, 一个有效的 JSON 字符串。
    replacer:可选。用于转换结果的函数或数组。
    如果 replacer 为函数,则 JSON.stringify 将调用该函数,并传入每个成员的键和值。使用返回值而不是原始值。如果此函数返回 undefined,则排除成员。根对象的键是一个空字符串:""。
    如果 replacer 是一个数组,则仅转换该数组中具有键值的成员。成员的转换顺序与键在数组中的顺序一样。当 value 参数也为数组时,将忽略 replacer 数组。
    space:可选,文本添加缩进、空格和换行符,如果 space 是一个数字,则返回值文本在每个级别缩进指定数目的空格,如果 space 大于 10,则文本缩进 10 个空格。space 有可以使用非数字,如: 。

    1. var obj = {"name":"runoob","alexa":10000,"site":"www.runoob.com"};
    2. var myJSON = JSON.stringify(obj);
    3. document.getElementById("demo").innerHTML = myJSON;

    JavaScript 函数 eval() 可用于将 JSON 文本转换为 JavaScript 对象:

    1. var txt = '{ "sites" : [' +'{"name":"菜鸟教程" , "url":"www.runoob.com" },' +'{ "name":"google" , "url":"www.google.com" },'+'{ "name":"微博" , "url":"www.weibo.com" } ]}';
    2. var obj = eval("("+ txt + ")");
    3. document.getElementById("name").innerHTML=obj.sites[0].name
    4. document.getElementById("url").innerHTML=obj.sites[0].url
  • 相关阅读:
    LeetCode 654. 最大二叉树
    LeetCode 617. 合并二叉树
    LeetCode 234. 回文链表
    LeetCode 328. 奇偶链表
    LeetCode 24. 两两交换链表中的节点
    LeetCode 21. 合并两个有序链表
    LeetCode 876. 链表的中间结点
    顺序表的定义及其相关基本操作
    LeetCode 206. 反转链表
    LeetCode 111. 二叉树的最小深度
  • 原文地址:https://www.cnblogs.com/jpfss/p/9543493.html
Copyright © 2020-2023  润新知