详解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 相关文章推荐
超轻量级的基于jquery的三级展开列表
Apr 26 Javascript
点击按钮自动加关注的代码(sina微博/QQ空间/人人网/腾讯微博)
Jan 02 Javascript
jquery中push()的用法(数组添加元素)
Nov 25 Javascript
jQuery实现简单的间隔向上滚动效果
Mar 09 Javascript
Javascript节点关系实例分析
May 15 Javascript
jQuery手机拨号界面特效代码分享
Aug 27 Javascript
JavaScript实现标题栏文字轮播效果代码
Oct 24 Javascript
JavaScript驾驭网页-DOM
Mar 24 Javascript
Vue系列:通过vue-router如何传递参数示例
Jan 16 Javascript
Angular.js中angular-ui-router的简单实践
Jul 18 Javascript
基于Datatables跳转到指定页的简单实例
Nov 09 Javascript
小程序从手动埋点到自动埋点的实现方法
Jan 24 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 SEO优化之URL优化方法
2011/04/21 PHP
应用开发中涉及到的css和php笔记分享
2011/08/02 PHP
php禁止浏览器使用缓存页面的方法
2014/11/07 PHP
php DES加密算法实例分析
2019/09/18 PHP
jQuery的链式调用浅析
2010/12/03 Javascript
window.event快达到全浏览器支持了,以后使用就方便了
2011/11/30 Javascript
JavaScript 高级篇之闭包、模拟类,继承(五)
2012/04/07 Javascript
获取数组中最大最小值方法js代码(自写)
2013/08/12 Javascript
webapp框架AngularUI的demo改造之路
2014/12/21 Javascript
JS实现网页表格自动变大缩小的方法
2015/03/09 Javascript
JavaScript中的this引用(推荐)
2016/08/05 Javascript
微信js-sdk地理位置接口用法示例
2016/10/12 Javascript
JS实现重新加载当前页面或者父页面的几种方法
2016/11/30 Javascript
js实现表格筛选功能
2017/01/18 Javascript
微信小程序页面跳转功能之从列表的item项跳转到下一个页面的方法
2017/11/27 Javascript
JS运动特效之同时运动实现方法分析
2018/01/24 Javascript
ionic grid(栅格)九宫格制作详解
2018/06/30 Javascript
Element DateTimePicker日期时间选择器的使用示例
2020/07/27 Javascript
自己编程中遇到的Python错误和解决方法汇总整理
2015/06/03 Python
Python for Informatics 第11章 正则表达式(一)
2016/04/21 Python
Python操作Access数据库基本步骤分析
2016/09/19 Python
用python处理图片之打开\显示\保存图像的方法
2018/05/04 Python
Python3自动签到 定时任务 判断节假日的实例
2018/11/13 Python
在django中使用apscheduler 执行计划任务的实现方法
2020/02/11 Python
Pycharm 如何一键加引号的方法步骤
2021/02/05 Python
BAILEY 44官网:美国制造的女性服装
2019/07/01 全球购物
班会关于环保演讲稿
2013/12/29 职场文书
服装创业计划书范文
2014/02/05 职场文书
2014年五四青年节演讲比赛方案
2014/04/22 职场文书
医院我们的节日活动实施方案
2014/08/22 职场文书
幼儿园三八妇女节活动总结
2015/02/06 职场文书
基层党建工作简报
2015/07/21 职场文书
2015国庆节放假通知范文
2015/07/30 职场文书
MySQL中distinct与group by之间的性能进行比较
2021/05/26 MySQL
DjangoRestFramework 使用 simpleJWT 登陆认证完整记录
2021/06/22 Python
MySQL中TIMESTAMP类型返回日期时间数据中带有T的解决
2022/12/24 MySQL