详解Javascript数据类型的转换规则


Posted in Javascript onDecember 12, 2016

一、数据类型

5种基本数据类型:Null/Undefined/String/Boolean/Number

1种复杂数据类型:Object

二、数据类型检测

传送门《JS中检测数据类型的几种方式及优缺点小结》

1、typeof

2、instanceof/constructor

3、Object.prototype.toString.call(value)

4、Object.prototype.toString

三、数据类型转换

JS内部提供不同数据类型的自动转换机制,在某处预期为某种类型而不是某种类型时,就会自动转换为预期类型,这就是我们常说的隐式转换。

1、强制类型转换

在了解隐式转换的规则前先来看看强制类型转换,强制类型转换主要是用Boolean()/String()/Number()将各类型的数据转换成布尔、字符串、数值型数据。

Boolean() 函数

当要转换的值是至少有一个字符的字符串、非 0 数字或对象时,Boolean() 函数将返回 true。如果该值是空字符串、数字 0、undefined 或 null,它将返回 false。

var b1 = Boolean(""); //false - 空字符串
var b2 = Boolean("hello"); //true - 非空字符串
var b1 = Boolean(50); //true - 非零数字
var b1 = Boolean(null); //false - null
var b1 = Boolean(0); //false - 零
var b1 = Boolean(new object()); //true - 对象

Number() 函数

Number() 函数的强制类型转换与 parseInt() 和 parseFloat() 方法的处理方式相似,只是它转换的是整个值,而不是部分值。

parseInt() 和 parseFloat() 方法只转换第一个无效字符之前的字符串,因此 "1.2.3" 将分别被转换为 "1" 和 "1.2"。

用 Number() 进行强制类型转换,"1.2.3" 将返回 NaN,因为整个字符串值不能转换成数字。如果字符串值能被完整地转换,Number() 将判断是调用 parseInt() 方法还是 parseFloat() 方法。

详解Javascript数据类型的转换规则

String() 函数

最后一种强制类型转换方法 String() 是最简单的,因为它可把任何值转换成字符串。

要执行这种强制类型转换,只需要调用作为参数传递进来的值的 toString() 方法,即把 12 转换成 "12",把 true 转换成 "true",把 false 转换成 "false",以此类推。

强制转换成字符串和调用 toString() 方法的唯一不同之处在于,对 null 和 undefined 值强制类型转换可以生成字符串而不引发错误:

var s1 = String(null); //"null"
var oNull = null;
var s2 = oNull.toString(); //会引发错误

2、自动类型转换

说完了强制类型转换,再来看看自动类型转换,实际上自动类型转换是建立在强制类型转换的基础上,当预期某个位置应该是某类型(布尔、数值、字符串)的数据时,就会调用相应的强制类型转换函数,这个是自动进行的。

*当JavaScript遇到预期为布尔值的地方(比如if语句的条件部分),就会将非布尔值的参数自动转换为布尔值。系统内部会自动调用Boolean函数。

因此除了以下六个值,其他都是自动转为true。

  • undefined
  • null
  • -0
  • 0或+0
  • NaN
  • ''(空字符串)

*当JavaScript遇到预期为字符串的地方,就会将非字符串的数据自动转为字符串。系统内部会自动调用String函数。

字符串的自动转换,主要发生在加法运算时。当一个值为字符串,另一个值为非字符串,则后者转为字符串。

*当JavaScript遇到预期为数值的地方,就会将参数值自动转换为数值。系统内部会自动调用Number函数。

除了加法运算符有可能把运算子转为字符串,其他运算符都会把运算子自动转成数值。

一元运算符也会把运算子转成数值。

+'abc' // NaN
-'abc' // NaN
+true // 1
-false // 0

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
JS 如果改变span标签的是否隐藏属性
Oct 06 Javascript
Javascript中匿名函数的多种调用方式总结
Dec 06 Javascript
asp.net+jquery.form实现图片异步上传的方法(附jquery.form.js下载)
May 05 Javascript
AngularJS上拉加载问题解决方法
May 23 Javascript
angularjs实现猜数字大小功能
May 20 Javascript
在Web关闭页面时发送Ajax请求的实现方法
Mar 07 Javascript
Vue数字输入框组件的使用方法
Oct 19 Javascript
Vue修改项目启动端口号方法
Nov 07 Javascript
详解ES6新增字符串扩张方法includes()、startsWith()、endsWith()
May 12 Javascript
ant-design-vue中tree增删改的操作方法
Nov 03 Javascript
微信小程序 接入腾讯地图的两种写法
Jan 12 Javascript
详解React中共享组件逻辑的三种方式
Feb 02 Javascript
设置jquery UI 控件的大小方法
Dec 12 #Javascript
JS中检测数据类型的几种方式及优缺点小结
Dec 12 #Javascript
JS仿京东移动端手指拨动切换轮播图效果
Apr 10 #Javascript
JavaScript版经典游戏之扫雷游戏完整示例【附demo源码下载】
Dec 12 #Javascript
JavaScript利用正则表达式替换字符串中的内容
Dec 12 #Javascript
基于BootstrapValidator的Form表单验证(24)
Dec 12 #Javascript
Sequelize中用group by进行分组聚合查询
Dec 12 #Javascript
You might like
php使用unset()删除数组中某个单元(键)的方法
2015/02/17 PHP
微信支付开发交易通知实例
2016/07/12 PHP
jQuery EasyUI API 中文文档 - Tabs标签页/选项卡
2011/10/01 Javascript
基于JavaScript实现百叶窗动画效果不只单纯flas可以实现
2016/02/29 Javascript
原生JS实现旋转木马式图片轮播插件
2016/04/25 Javascript
React实现双向绑定示例代码
2016/09/19 Javascript
js判断价格,必须为数字且不能为负数的实现方法
2016/10/07 Javascript
详解vue-cli中配置sass
2017/06/21 Javascript
JS 判断某变量是否为某数组中的一个值的3种方法(总结)
2017/07/10 Javascript
JQuery 获取多个select标签option的text内容(实例)
2017/09/07 jQuery
微信小程序实现下拉刷新和轮播图效果
2017/11/21 Javascript
jquery动态添加以及遍历option并获取特定样式名称的option方法
2018/01/29 jQuery
手写简单的jQuery雪花飘落效果实例
2018/04/22 jQuery
Nodejs实现爬虫抓取数据实例解析
2018/07/05 NodeJs
[15:56]Heroes18_暗影萨满(完美)
2014/10/31 DOTA
Python文件操作类操作实例详解
2014/07/11 Python
Python写的Tkinter程序屏幕居中方法
2015/03/10 Python
Python编写简单的HTML页面合并脚本
2016/07/11 Python
python批量从es取数据的方法(文档数超过10000)
2018/12/27 Python
python找出一个列表中相同元素的多个索引实例
2019/06/11 Python
Python为何不能用可变对象作为默认参数的值
2019/07/01 Python
对Python生成器、装饰器、递归的使用详解
2019/07/19 Python
python安装virtualenv虚拟环境步骤图文详解
2019/09/18 Python
python使用matplotlib:subplot绘制多个子图的示例
2020/09/24 Python
css3实现背景颜色渐变让图片不再是唯一的实现方式
2012/12/18 HTML / CSS
财务会计专业应届毕业生求职信
2013/10/18 职场文书
制冷与空调专业毕业生推荐信
2014/07/07 职场文书
课前一分钟演讲稿
2014/08/26 职场文书
2014年乡镇领导个人整改措施
2014/09/19 职场文书
离婚协议书标准格式
2014/10/04 职场文书
《改造我们的学习》心得体会
2014/11/07 职场文书
客户经理岗位职责
2015/01/31 职场文书
运动会宣传稿100字
2015/07/23 职场文书
学困生帮扶工作总结
2015/08/13 职场文书
2021年国漫热度排行前十,完美世界上榜,第四是美国动画作品
2022/03/18 国漫
canvas 中如何实现物体的框选
2022/08/05 Javascript