美文网首页
js笔记08-json

js笔记08-json

作者: 大飞哥 | 来源:发表于2018-01-24 17:56 被阅读9次

    JSON (/ˈdʒeɪsən/ JAY-sən)

    json的数据类型:

    • number:和JavaScript的number完全一致;
    • boolean:就是JavaScript的truefalse
    • string:就是JavaScript的string
    • null:就是JavaScript的null
    • array:就是JavaScript的Array表示方式——[]
    • object:就是JavaScript的{ ... }表示方式。

    字符集必须是UTF-8
    JSON的字符串规定必须用双引号""
    Object的键也必须用双引号""

    序列化

    把小明这个对象序列化成JSON格式的字符串:

    'use strict';
    
    var xiaoming = {
        name: '小明',
        age: 14,
        gender: true,
        height: 1.65,
        grade: null,
        'middle-school': '\"W3C\" Middle School',
        skills: ['JavaScript', 'Java', 'Python', 'Lisp']
    };
    
    var s = JSON.stringify(xiaoming);
    console.log(s);
    
    
    //优化显示
    JSON.stringify(xiaoming, null, '  ');
    //输出
    /*
    {
      "name": "小明",
      "age": 14,
      "gender": true,
      "height": 1.65,
      "grade": null,
      "middle-school": "\"W3C\" Middle School",
      "skills": [
        "JavaScript",
        "Java",
        "Python",
        "Lisp"
      ]
    }
    */
    //第二个参数用于控制如何筛选对象的键值,如果我们只想输出指定的属性,可以传入Array:
    JSON.stringify(xiaoming, ['name', 'skills'], '  ');
    /*
    {
      "name": "小明",
      "skills": [
        "JavaScript",
        "Java",
        "Python",
        "Lisp"
      ]
    }
    */
    //也可以传入函数
    function convert(key, value) {
        if (typeof value === 'string') {
            return value.toUpperCase();
        }
        return value;
    }
    
    JSON.stringify(xiaoming, convert, '  ');
    //输出
    /*
    {
      "name": "小明",
      "age": 14,
      "gender": true,
      "height": 1.65,
      "grade": null,
      "middle-school": "\"W3C\" MIDDLE SCHOOL",
      "skills": [
        "JAVASCRIPT",
        "JAVA",
        "PYTHON",
        "LISP"
      ]
    }
    */
    
    //精确控制如何序列化小明,xiaoming里面定义一个toJSON()的方法
    
    var xiaoming = {
        name: '小明',
        age: 14,
        gender: true,
        height: 1.65,
        grade: null,
        'middle-school': '\"W3C\" Middle School',
        skills: ['JavaScript', 'Java', 'Python', 'Lisp'],
        toJSON: function () {
            return { // 只输出name和age,并且改变了key:
                'Name': this.name,
                'Age': this.age
            };
        }
    };
    
    JSON.stringify(xiaoming); // '{"Name":"小明","Age":14}'
    

    反序列化

    一个JSON格式的字符串,我们直接用JSON.parse()把它变成一个JavaScript对象

    JSON.parse('[1,2,3,true]'); // [1, 2, 3, true]
    JSON.parse('{"name":"小明","age":14}'); // Object {name: '小明', age: 14}
    JSON.parse('true'); // true
    JSON.parse('123.45'); // 123.45
    

    JSON.parse()还可以接收一个函数,用来转换解析出的属性:

    var obj = JSON.parse('{"name":"小明","age":14}', function (key, value) {
        if (key === 'name') {
            return value + '同学';
        }
        return value;
    });
    console.log(JSON.stringify(obj)); // {name: '小明同学', age: 14}
    

    相关文章

      网友评论

          本文标题:js笔记08-json

          本文链接:https://www.haomeiwen.com/subject/ujnuaxtx.html