详解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 相关文章推荐
比较简单的一个符合web标准的JS调用flash方法
Nov 29 Javascript
Javascript常用运算符(Operators)-javascript基础教程
Dec 14 Javascript
jQuery中校验时间格式的正则表达式小结
Sep 22 Javascript
让浏览器DOM元素最后加载的js方法
Jul 29 Javascript
浅谈JavaScript 浏览器对象
Jun 03 Javascript
微信小程序 WebSocket详解及应用
Jan 21 Javascript
BootStrap 表单控件之单选按钮水平排列
May 23 Javascript
js数据类型检测总结
Aug 05 Javascript
vue实现在线翻译功能
Sep 27 Javascript
vue中el-input绑定键盘按键(按键修饰符)
Jul 22 Javascript
用webAPI实现图片放大镜效果
Nov 23 Javascript
深入理解javascript中的this
Feb 08 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
全国FM电台频率大全 - 28 甘肃省
2020/03/11 无线电
apache2.2.4+mysql5.0.77+php5.2.8安装精简
2009/04/29 PHP
Yii PHP Framework实用入门教程(详细介绍)
2013/06/18 PHP
PHP实现的折半查找算法示例
2017/12/19 PHP
php xhprof使用实例详解
2019/04/15 PHP
List Information About the Binary Files Used by an Application
2007/06/11 Javascript
用于判断用户注册时,密码强度的JS代码
2009/01/01 Javascript
JQuery toggle使用分析
2009/11/16 Javascript
动感效果的TAB选项卡jquery 插件
2011/07/09 Javascript
用javascript为页面添加天气显示实现思路及代码
2013/12/02 Javascript
FireBug 调试JS入门教程 如何调试JS
2013/12/23 Javascript
javascript解析json数据的3种方式
2014/05/08 Javascript
js简单正则验证汉字英文及下划线的方法
2016/11/28 Javascript
Jquery EasyUI Datagrid右键菜单实现方法
2016/12/30 Javascript
layui分页效果实现代码
2017/05/19 Javascript
解决Vue页面固定滚动位置的处理办法
2017/07/13 Javascript
bootstrap table表格插件之服务器端分页实例代码
2018/09/12 Javascript
Vue中对拿到的数据进行A-Z排序的实例
2018/09/25 Javascript
Vue源码探究之状态初始化
2018/11/14 Javascript
Layui之table中的radio在切换分页时无法记住选中状态的解决方法
2019/09/02 Javascript
Vue 实现点击空白处隐藏某节点的三种方式(指令、普通、遮罩)
2019/10/23 Javascript
Python实现读取机器硬件信息的方法示例
2018/06/09 Python
pyqt5的QComboBox 使用模板的具体方法
2018/09/06 Python
解决PyCharm import torch包失败的问题
2018/10/13 Python
在python中实现同行输入/接收多个数据的示例
2019/07/20 Python
python 实现手机自动拨打电话的方法(通话压力测试)
2019/08/08 Python
Python decimal模块使用方法详解
2020/06/08 Python
python 动态绘制爱心的示例
2020/09/27 Python
Conforama西班牙:您的家具、装饰和电器商店
2020/02/21 全球购物
澳大利亚香水在线商店:City Perfume
2020/09/02 全球购物
综合办公室个人的自我评价
2013/12/22 职场文书
党的群众路线教育实践活动领导班子对照检查材料
2014/09/25 职场文书
2014光棍节大学生联谊活动方案
2014/10/10 职场文书
车间班组长竞聘书
2015/09/15 职场文书
普希金诗歌赏析(6首)
2019/08/22 职场文书
mysql中数据库覆盖导入的几种方式总结
2022/03/25 MySQL