手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >你必须知道的Javascript知识点之"字面量和对应类型"说明介绍
你必须知道的Javascript知识点之"字面量和对应类型"说明介绍
摘要:代码示例:复制代码代码如下:vardate1=newDate(2013,1,1);vardate2=newDate(2013,1,1);da...

代码示例:

复制代码 代码如下:

var date1 = new Date(2013,1,1);

var date2 = new Date(2013,1,1);

date1 == date2; //执行结果为false

date1 === date2; //执行结果为false

var num1 = new Number(10);

var num2 = new Number(10);

num1 == num2; //执行结果为false

num1 === num2; //执行结果为false

num1 == 10; //执行结果为true

10 == num2; //执行结果为true

num1 === 10; //执行结果为false

10 === num2; //执行结果为false

之所以要写这个主题,是因为日期类型的比较经常会出现意想不到的错误,几乎每个刚接触javascript的开发人员都会遇到这个问题。

到底是为什么

规则1

javascript中一切都是对象(引用类型),除了这几个类型的字面量(值类型):Boolean(如:true)、Number(如:100)、undefined、null。

规则2

引用类型之间用"=="或“===”做比较运算时,只要两者不是指向同一份内存地址,都会返回false。

代码示例

复制代码 代码如下:

var date1 = new Date(2013,1,1);

var date2 = new Date(2013,1,1);

date1 == date2; //执行结果为false

date1 === date2; //执行结果为false

图片示意

你必须知道的Javascript知识点之"字面量和对应类型"说明介绍1

规则3

引用类型和对应的值类型之间用“=="做比较运算时,会先进行类型转换,然后进行比较。

代码示例

复制代码 代码如下:

var num1 = new Number(10);

var num2 = new Number(10);

num1 == 10; //执行结果为true

10 == num2; //执行结果为true

规则4引用类型和对应的值类型之间用“==="做比较运算时,始终返回false。

代码示例

复制代码 代码如下:

var num1 = new Number(10);

var num2 = new Number(10);

num1 === 10; //执行结果为false

10 === num2; //执行结果为false

特殊的String类型

string是特殊的引用类型,javascript解释器遇到两个一样的字面量会未他们分配同一个内存地址,javascript本身也保持值语义(一旦创建不能修改)。

代码示例

复制代码 代码如下:

var str1 = new String('hello');

var str2 = new String('hello');

var str3 = 'hello';

var str4 = 'hello';

str1 == str2 //指向结果为false

str1 === str2 //指向结果为false

str3 == str4 //指向结果为true

str3 === str4 //指向结果为true

str2 == str4 //指向结果为true

str2 === str4 //指向结果为false

图片示意

你必须知道的Javascript知识点之"字面量和对应类型"说明介绍2

值类型的内存格局

代码示例

1 var num1 = 1;2 var num2 = 1;

图片示意

你必须知道的Javascript知识点之"字面量和对应类型"说明介绍3

【你必须知道的Javascript知识点之"字面量和对应类型"说明介绍】相关文章:

javascript基础知识分享之类与函数化

JQuery控制Radio选中方法分析

javascript验证邮件地址和MX记录的方法

javascript插件开发的一些感想和心得

Javascript实现图片轮播效果(二)图片序列节点的控制实现

简单分析javascript面向对象与原型

jQuery解析XML文件同时动态增加js文件的方法

Web开发必知Javascript技巧大全

JavaScript获得指定对象大小的方法

解析Node.js基于模块和包的代码部署方式

精品推荐
分类导航