详解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 处理网页内容的实现代码
Feb 15 Javascript
JavaScript与Div对层定位和移动获得坐标的实现代码
Sep 08 Javascript
MooBox 基于Mootools的对话框插件
Jan 20 Javascript
Firefox/Chrome/Safari的中可直接使用$/$$函数进行调试
Feb 13 Javascript
jquery库文件略庞大用纯js替换jquery的方法
Aug 12 Javascript
浅谈Javascript线程及定时机制
Jul 02 Javascript
JS在onclientclick里如何控制onclick的执行
May 30 Javascript
jQuery实现优雅的弹窗效果(6)
Feb 08 Javascript
Vue实现购物车场景下的应用
Nov 27 Javascript
微信小程序自定义prompt组件步骤详解
Jun 12 Javascript
vue实现重置表单信息为空的方法
Sep 29 Javascript
vue组件间通信六种方式(总结篇)
May 15 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 中英文混合排版中处理字符串常用的函数
2007/04/12 PHP
php 网页游戏开发入门教程一(webgame+design)
2009/10/26 PHP
php若干单维数组遍历方法的比较
2011/09/20 PHP
微信支付PHP SDK ―― 公众号支付代码详解
2016/09/13 PHP
PHP中quotemeta()函数的用法讲解
2019/04/04 PHP
Javascript根据指定下标或对象删除数组元素
2012/12/21 Javascript
jquery获取复选框被选中的值
2014/03/22 Javascript
jQuery遍历Table应用示例
2014/04/09 Javascript
JS+CSS实现的漂亮渐变背景特效代码(6个渐变效果)
2016/03/25 Javascript
JavaScript面向对象程序设计教程
2016/03/29 Javascript
微信小程序 解决请求服务器手机预览请求不到数据的方法
2017/01/04 Javascript
js实现随机抽选效果、随机抽选红色球效果
2017/01/13 Javascript
深入理解JavaScript中的for循环
2017/02/07 Javascript
css和js实现弹出登录居中界面完整代码
2017/11/26 Javascript
详解Nodejs mongoose
2018/06/10 NodeJs
angularJS1 url中携带参数的获取方法
2018/10/09 Javascript
JavaScript中关于base64的一些事
2019/05/06 Javascript
微信小程序获取位置展示地图并标注信息的实例代码
2019/09/01 Javascript
Vue-router中hash模式与history模式的区别详解
2020/12/15 Vue.js
JavaScript点击按钮生成4位随机验证码
2021/01/28 Javascript
[32:26]EG vs IG 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
零基础写python爬虫之使用Scrapy框架编写爬虫
2014/11/07 Python
python使用multiprocessing模块实现带回调函数的异步调用方法
2015/04/18 Python
python XlsxWriter模块创建aexcel表格的实例讲解
2018/05/03 Python
python仿evething的文件搜索器实例代码
2019/05/13 Python
Django 允许局域网中的机器访问你的主机操作
2020/05/13 Python
html5 input属性使用示例
2013/06/28 HTML / CSS
澳大利亚天然护肤品、化妆品和健康产品一站式商店:Nourished Life
2018/12/02 全球购物
安全检查与奖惩制度
2014/01/23 职场文书
团日活动总结报告
2014/06/25 职场文书
研修心得体会
2014/09/04 职场文书
外出培训学习心得体会
2016/01/18 职场文书
安全生产学习心得体会
2016/01/18 职场文书
2016年艾滋病宣传活动总结
2016/04/01 职场文书
Python3.10的一些新特性原理分析
2021/09/15 Python
win10电脑老是死机怎么办?win10系统老是死机的解决方法
2022/08/05 数码科技