登录  /  注册
首页 > web前端 > js教程 > 正文
你必须知道的Javascript知识点之"字面量和对应类型"说明介绍_javascript技巧
php中文网
发布: 2016-05-16 17:35:50
原创
858人浏览过

代码示例:

复制代码 代码如下:

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

图片示意

规则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

图片示意

值类型的内存格局

代码示例

1 var num1 = 1;2 var num2 = 1;
登录后复制

图片示意

相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 技术文章
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2023 //m.sbmmt.com/ All Rights Reserved | 苏州跃动光标网络科技有限公司 | 苏ICP备2020058653号-1

 | 本站CDN由 数掘科技 提供

登录PHP中文网,和优秀的人一起学习!
全站2000+教程免费学