0、写在前面的话

在JS世界中,一切都是对象,区别对象类型使用tyepof,返回一个字符串,如:
typeof 123; // 'number'
typeof NaN; // 'number'
typeof 'str'; // 'string'
typeof true; // 'boolean'
typeof undefined; // 'undefined'
typeof Math.abs; // 'function'
typeof null; // 'object'
typeof []; // 'object'
typeof {}; // 'object'
9
 
1
typeof 123; // 'number' 
2
typeof NaN; // 'number'
3
typeof 'str'; // 'string'
4
typeof true; // 'boolean'
5
typeof undefined; // 'undefined'
6
typeof Math.abs; // 'function'
7
typeof null; // 'object'
8
typeof []; // 'object'
9
typeof {}; // 'object'

和Java类似,JS中也提供了包装对象,使用new创建,变成Object后同Java中类似,直接使用===对比会返回false:
var n = new Number(123); // 123,生成了新的包装类型
var b = new Boolean(true); // true,生成了新的包装类型
var s = new String('str'); // 'str',生成了新的包装类型
3
 
1
var n = new Number(123); // 123,生成了新的包装类型
2
var b = new Boolean(true); // true,生成了新的包装类型
3
var s = new String('str'); // 'str',生成了新的包装类型

不写new,直接使用 Number() 诸如此类,是强转类型的函数:
var n = Number('123'); // 123,相当于parseInt()或parseFloat()
typeof n; // 'number' var b = Boolean('true'); // true
typeof b; // 'boolean' var b2 = Boolean('false'); // true! 'false'字符串转换结果为true!因为它是非空字符串!
var b3 = Boolean(''); // false var s = String(123.45); // '123.45'
typeof s; // 'string'
11
 
1
var n = Number('123'); // 123,相当于parseInt()或parseFloat()
2
typeof n; // 'number'
3

4
var b = Boolean('true'); // true
5
typeof b; // 'boolean'
6

7
var b2 = Boolean('false'); // true! 'false'字符串转换结果为true!因为它是非空字符串!
8
var b3 = Boolean(''); // false
9

10
var s = String(123.45); // '123.45'
11
typeof s; // 'string'

总结一下规则:
  • 不要使用new Number()、new Boolean()、new String()创建包装对象
    • 包装对象创建/实例化出来的,是对象类型,而不是Number/Boolean/String类型

  • 类型转换
    • 用parseInt()或parseFloat()来转换任意类型到number
    • 用String()来转换任意类型到string,或者直接调用某个对象的toString()方法

  • 类型判断
    • 通常不必把任意类型转换为boolean再判断,因为可以直接写if (myVar) {...}
    • typeof操作符可以判断出number、boolean、string、function和undefined
    • 判断Array要使用Array.isArray(arr)
    • 判断null请使用myVar === null

  • 判断存在性
    • 判断某个全局变量是否存在用typeof window.myVar === 'undefined'
    • 函数内部判断某个变量是否存在用typeof myVar === 'undefined'

  • 其他
    • null 和 undefined 没有toString()方法
    • number对象调用toString()会报错,需要处理一下: 123.toString() //SyntaxError   (123).toString(); // '123'


1、Date

多说无意,看代码:
var now = new Date();
now; // Wed Jun 24 2015 19:49:22 GMT+0800 (CST)
now.getFullYear(); // 2015, 年份
now.getMonth(); // 5, 月份,注意月份范围是0~11,5表示六月
now.getDate(); // 24, 表示24号
now.getDay(); // 3, 表示星期三
now.getHours(); // 19, 24小时制
now.getMinutes(); // 49, 分钟
now.getSeconds(); // 22, 秒
now.getMilliseconds(); // 875, 毫秒数
now.getTime(); // 1435146562875, 以number形式表示的时间戳
11
 
1
var now = new Date();
2
now; // Wed Jun 24 2015 19:49:22 GMT+0800 (CST)
3
now.getFullYear(); // 2015, 年份
4
now.getMonth(); // 5, 月份,注意月份范围是0~11,5表示六月
5
now.getDate(); // 24, 表示24号
6
now.getDay(); // 3, 表示星期三
7
now.getHours(); // 19, 24小时制
8
now.getMinutes(); // 49, 分钟
9
now.getSeconds(); // 22, 秒
10
now.getMilliseconds(); // 875, 毫秒数
11
now.getTime(); // 1435146562875, 以number形式表示的时间戳

注意:该时间是从本机操作系统获取的时间,如果用户将当前时间设定为其他的值,那么获取的时间也是不同的。

Date对象表示的时间总是按浏览器所在的时区显示的,可以通过方法显示本地时间,或调整后的UTC时间:
var d = new Date(1435146562875);
d.toLocaleString(); // '2015/6/24 下午7:49:22',本地时间(北京时区+8:00),显示的字符串与操作系统设定的格式有关
d.toUTCString(); // 'Wed, 24 Jun 2015 11:49:22 GMT',UTC时间,与本地时间相差8小时
3
 
1
var d = new Date(1435146562875);
2
d.toLocaleString(); // '2015/6/24 下午7:49:22',本地时间(北京时区+8:00),显示的字符串与操作系统设定的格式有关
3
d.toUTCString(); // 'Wed, 24 Jun 2015 11:49:22 GMT',UTC时间,与本地时间相差8小时

这里传递的参数实际上是一个number类型的时间戳,之前我们的示例代码中提到过,一个Date对象使用getTime方法可以得到number形式的时间戳。

*时间戳:从1970年1月1日零时整的GMT时区开始,到现在此刻的毫秒数,是一个自增的整数。


2、JSON

其实把JSON和之前的Date放在同一个博文里似乎有些不合适,Date确实是一个对象,但是JSON实际上说来是一种数据格式。不过,先这样吧,谁让我懒呢。

另,之前关于JSON专门写过一篇入门小博文,可以戳下再了解下:《JSON的基本结构和数据交换原理

简单说来,JSON就是一种轻量级的数据交换格式,比XML轻量很多,发明这个格式的人钟情于JavaScript,所以设计的JSON实际上就是JavaScript的子集,所以JS中可以直接使用JSON,因为JS中内置了JSON的解析。

也因如此,JSON作为一种数据交换格式,其定义的数据类型也就跟JS基本一样:
  • number
  • boolean
  • string
  • array
  • object
  • null

JSON还定死了字符集必须是UTF-8。为统一解析,JSON的字符串规定必须用双引号"",Object的键也必须用双引号""。

最后:
  • JS对象变成JSON,就是把这个对象序列化成JSON格式的字符串,就能够通过网络传递到其他计算机
  • 收到JSON格式字符串,只需要反序列化成为JS对象,就可以在JavaScript中直接使用这个对象了

2.1 序列化 JSON.stringify()

假如有一个小明对象,我们要将这个对象序列化成JSON格式的字符串:
var xiaoming = {
name: '小明',
age: 14,
gender: true,
height: 1.65,
grade: null,
'middle-school': '\"W3C\" Middle School',
skills: ['JavaScript', 'Java', 'Python', 'Lisp']
}; JSON.stringify(xiaoming); 
//'{"name":"小明","age":14,"gender":true,"height":1.65,"grade":null,"middle-school":"\"W3C\" Middle School","skills":["JavaScript","Java","Python","Lisp"]}'
12
 
1
var xiaoming = {
2
    name: '小明',
3
    age: 14,
4
    gender: true,
5
    height: 1.65,
6
    grade: null,
7
    'middle-school': '\"W3C\" Middle School',
8
    skills: ['JavaScript', 'Java', 'Python', 'Lisp']
9
};
10

11
JSON.stringify(xiaoming); 
12
//'{"name":"小明","age":14,"gender":true,"height":1.65,"grade":null,"middle-school":"\"W3C\" Middle School","skills":["JavaScript","Java","Python","Lisp"]}'

为了输出好看些,可以加上参数,按缩进输出:
JSON.stringify(xiaoming, null, '  ');

//结果
{
"name": "小明",
"age": 14,
"gender": true,
"height": 1.65,
"grade": null,
"middle-school": "\"W3C\" Middle School",
"skills": [
"JavaScript",
"Java",
"Python",
"Lisp"
]
}
17
 
1
JSON.stringify(xiaoming, null, '  ');
2

3
//结果
4
{
5
  "name": "小明",
6
  "age": 14,
7
  "gender": true,
8
  "height": 1.65,
9
  "grade": null,
10
  "middle-school": "\"W3C\" Middle School",
11
  "skills": [
12
    "JavaScript",
13
    "Java",
14
    "Python",
15
    "Lisp"
16
  ]
17
}

第二个参数用于控制如何筛选对象的键值,如果只想输出指定的属性,可以传入Array:
JSON.stringify(xiaoming, ['name', 'skills'], '  ');

//结果
{
"name": "小明",
"skills": [
"JavaScript",
"Java",
"Python",
"Lisp"
]
}
12
 
1
JSON.stringify(xiaoming, ['name', 'skills'], '  ');
2

3
//结果
4
{
5
  "name": "小明",
6
  "skills": [
7
    "JavaScript",
8
    "Java",
9
    "Python",
10
    "Lisp"
11
  ]
12
}

第二个参数还可以传入函数,这样每个键值对都会被函数先处理:
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"
]
}
24
 
1
function convert(key, value) {
2
    if (typeof value === 'string') {
3
        return value.toUpperCase();
4
    }
5
    return value;
6
}
7

8
JSON.stringify(xiaoming, convert, '  ');
9

10
//结果:把所有属性值变成大写
11
{
12
  "name": "小明",
13
  "age": 14,
14
  "gender": true,
15
  "height": 1.65,
16
  "grade": null,
17
  "middle-school": "\"W3C\" MIDDLE SCHOOL",
18
  "skills": [
19
    "JAVASCRIPT",
20
    "JAVA",
21
    "PYTHON",
22
    "LISP"
23
  ]
24
}

如果我们还想要精确控制如何序列化小明,可以给xiaoming定义一个toJSON()的方法,直接返回JSON应该序列化的数据:
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}'
x
 
1
var xiaoming = {
2
    name: '小明',
3
    age: 14,
4
    gender: true,
5
    height: 1.65,
6
    grade: null,
7
    'middle-school': '\"W3C\" Middle School',
8
    skills: ['JavaScript', 'Java', 'Python', 'Lisp'],
9
    toJSON: function () {
10
        return { // 只输出name和age,并且改变了key:
11
            'Name': this.name,
12
            'Age': this.age
13
        };
14
    }
15
};
16

17
JSON.stringify(xiaoming); // '{"Name":"小明","Age":14}'

2.2 反序列化

拿到一个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
4
 
1
JSON.parse('[1,2,3,true]'); // [1, 2, 3, true]
2
JSON.parse('{"name":"小明","age":14}'); // Object {name: '小明', age: 14}
3
JSON.parse('true'); // true
4
JSON.parse('123.45'); // 123.45

序列化中我们可以对方法增加函数,进行预处理,同理,在反序列化中,我们也可以让JSON.parse()接收一个函数,用来转换解析出的属性:
JSON.parse('{"name":"小明","age":14}', function (key, value) {
// 把number * 2:
if (key === 'name') {
return value + '同学';
}
return value;
}); // Object {name: '小明同学', age: 14}
7
 
1
JSON.parse('{"name":"小明","age":14}', function (key, value) {
2
    // 把number * 2:
3
    if (key === 'name') {
4
        return value + '同学';
5
    }
6
    return value;
7
}); // Object {name: '小明同学', age: 14}

实际上,还有第二种方式可以将JSON格式的字符串转换为JS对象,使用eval函数:
eval(string);
//eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码
2
 
1
eval(string);
2
//eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码

可能有人要疑惑,为什么JSON格式的字符串,可以计算执行成为一个JS对象呢?因为JSON格式的字符串其实可以说是一种 “对象字面量”,执行这个字符串自然也就对应生成了对象。值得注意的是,为了避免JSON中花括号被当成语句块处理,我们在使用eval方法时,要对JSON格式的字符串加上括号。

所以,JSON.parse(jsonStr)的方式,也可以写成下面格式:
var xiaoming = '{"name":"小明", "age":14}';
var jsObj = eval("(" + xiaoming + ")");
 
1
var xiaoming = '{"name":"小明", "age":14}';
2
var jsObj = eval("(" + xiaoming + ")");

*字面量:由语法表达式定义的常量,或你可以理解为,是通过由一定字词组成的语词表达式定义的常量


03标准对象-01-Date和JSON的更多相关文章

  1. # 095 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 03 封装总结 01 封装知识点总结

    095 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 ...

  2. 094 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 02 static关键字 04 static关键字(续)

    094 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 ...

  3. 093 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 02 static关键字 03 static关键字(下)

    093 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 ...

  4. 092 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 02 static关键字 02 static关键字(中)

    092 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 ...

  5. 091 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 02 static关键字 01 static关键字(上)

    091 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 ...

  6. 090 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 04 使用包进行类管理(2)——导入包

    090 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 ...

  7. 089 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 使用包进行类管理(1)——创建包

    089 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 ...

  8. Math, Date,JSON对象

    Math 对象 Math是 JavaScript 的原生对象,提供各种数学功能.该对象不是构造函数,不能生成实例,所有的属性和方法都必须在Math对象上调用. 静态属性 Math对象的静态属性,提供以 ...

  9. JSON Date Format/JSON 日期格式方法分享

    我是很懒的,不想多说,所以直接上代码.亲们懂的. <!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://w ...

随机推荐

  1. noip普及组2004 花生采摘

    花生采摘 描述 鲁宾逊先生有一只宠物猴,名叫多多.这天,他们两个正沿着乡间小路散步,突然发现路的告示牌上贴着一张小小的纸条:"欢迎免费品尝我种的花生!--熊字". 鲁宾逊先生和多多 ...

  2. 基于tgp协议的套接字的 粘包解决

    客户端 import socket import struct import json phone = socket.socket(socket.AF_INET, socket.SOCK_STREAM ...

  3. <花儿与少年>之一些很喜欢的台词收藏

    花儿与少年... ================= 作为一个普通观众,现在这样的花少冒险之旅很好,有旅行.有冒险.有不和.有理解,有时候节目为了效果要制造一些争锋相对的场面,但是除此之外,整个节目质 ...

  4. 初入angular4——实际项目搭建总结

    前言 接到一个pc端后台项目,还会加入两个安卓同事一起学习和做这个项目,需要带一下他们. 既ng1之后,我就没怎么有过其它后台框架的实际项目经验了,期间用的移动端框架也并非vue.angular系列. ...

  5. 使用VMware Workstation安装win7镜像文件时遇见的错误

    最近打算使用虚拟机安装个系统玩玩,就去网站上找了教程安装下win7系统.但是在安装过程中遇见两个问题,现在把遇见的问题总结记录一下,以及解决方法罗列一下. 我当时使用的是VMware 12版的,系统是 ...

  6. Centos7.2下Nginx配置SSL支持https访问(站点是基于.Net Core2.0开发的WebApi)

    准备工作 1.基于nginx部署好的站点(本文站点是基于.Net Core2.0开发的WebApi,有兴趣的同学可以跳http://www.cnblogs.com/GreedyL/p/7422796. ...

  7. pycharm激活

    刚刚下载了2017.1版本专业版的pycharm,作为一个天朝开发者,自然是去找注册码了.转悠了一圈,那些注册码都已经失效了.看到一个有效的方法:把http://elporfirio.com:1017 ...

  8. Begin the new life as a coder

    今天刚刚开通博客园的博客频道,这里将成为自我成长点滴记录的土壤!从今天开始,从这篇博文开始,我将分享自己从一个fresher开始的成长经历.原与广大仁人志士共同在程序中共享快乐!我真是太高兴了 :D

  9. 微信中通过页面(H5)直接打开本地app的解决方案

    简述 微信中通过页面直接打开app分为安卓版和IOS版,两个的实现方式是完全不同的. 安卓版实现:使用腾讯的应用宝,只要配置了“微下载”之后,打开链接腾讯会帮你判断本地是否已经安装了app,如果本地安 ...

  10. 搭建LAMP及wordpress

    author:JevonWei 版权声明:原创作品 安装软件包 [root@danran ~]# yum -y install httpd mariadb-server mariadb php php ...