JavaScript 基本数据类型转换

简介: 数据类型转换是我们在前端开发中经常遇到的场景,一般而言,在 JavaScript 中类型转换有三种情况

3.png


前言


数据类型转换是我们在前端开发中经常遇到的场景,一般而言,在 JavaScript 中类型转换有三种情况:


  • 转换为数字(调用 Number(),parseInt(),parseFloat()方法)
  • 转换为字符串(调用.toString()或 String()方法)
  • 转换为布尔值(调用 Boolean()方法)


需要注意的是:null、undefined 没有.toString() 方法


转换为数字


Number(string) 方法


Number() 可以把任意值转换成数字,如果要转换的目标对象(一般是字符串)中有不是数字的值,则会返回 NaN


Number('1')   // 1
Number(true)  // 1
Number('123s') // NaN
Number({})  //NaN


parseInt(string, radix)


解析一个字符串并返回指定基数的十进制整数,radix 是 2-36 之间的整数,表示被解析字符串的基数。


parseInt('2') //2
parseInt('2',10) // 2
parseInt('2',2)  // NaN
parseInt('a123')  // NaN  如果第一个字符不是数字或者符号就返回NaN
parseInt('123a')  // 123


parseFloat(string)


解析一个参数并返回一个浮点数。


parseFloat('123a')  //123
parseFloat('123a.01')   //123
parseFloat('123.01')    //123.01
parseFloat('123.01.1')  //123.01


隐式转换


let str = '123'
-str    // -123
str+1 // '1231'
+str+1 // 124
let res = str - 1 //122


转换为字符串


toString()


将目标对象转换为字符串。


注意:null,undefined 不能调用。


Number(123).toString()  //'123'
[].toString()   //''
true.toString() //'true'


String()


String() 的作用比较强大,它可以将任何传入的值都转为字符串。


String(123) //'123'
String(true)    //'true'
String([])  //''
String(null)    //'null'
String(undefined)   //'undefined'
String({})  //'[object Object]'


隐式转换


当 + 两边有一个是字符串,另一个是其它类型时,会先把其它类型转换为字符串再进行字符串拼接,返回字符串:


let a = 1
a + ''  // '1'


转换为布尔值


Boolean()


Boolean() 方法会将以下值转换为 false:


  • 0
  • ""
  • null
  • undefined
  • NaN


其余的所有值都会被转换为 true。


Boolean('') //false
Boolean(0) //false
Boolean(1) //true
Boolean(null) //false
Boolean(undefined) //false
Boolean(NaN) //false
Boolean({}) //true
Boolean([]) //true


条件语句


在条件语句中,我们一般不会主动进行布尔转换。


let a
if(a) {
  //...   //这里a为undefined,会转为false,所以该条件语句内部不会执行
}


隐式转换


let str = '111'
console.log(!!str) // true


总结


以上就是 JavaScript 基本数据类型转换相关的知识总结,其中最需要注意的是隐士转换。


~本文完,感谢阅读!


学习有趣的知识,结识有趣的朋友,塑造有趣的灵魂!


你来,怀揣期望,我有墨香相迎! 你归,无论得失,唯以余韵相赠!


知识与技能并重,内力和外功兼修,理论和实践两手都要抓、两手都要硬!




相关文章
|
2月前
|
存储 JavaScript 前端开发
【JavaScript技术专栏】JavaScript基础入门:变量、数据类型与运算符
【4月更文挑战第30天】本文介绍了JavaScript的基础知识,包括变量(var、let、const)、数据类型(Number、String、Boolean、Undefined、Null及Object、Array)和运算符(算术、赋值、比较、逻辑)。通过实例展示了如何声明变量、操作数据类型以及使用运算符执行数学和逻辑运算。了解这些基础知识对初学者至关重要,是进阶学习JavaScript的关键。
|
17天前
|
JavaScript 前端开发 开发者
JavaScript数据类型概述及Undefined与Null详解
JavaScript数据类型概述及Undefined与Null详解
21 3
|
20天前
|
JavaScript 前端开发 索引
JavaScript有7个数据类型:Number, String, Boolean, Null, Undefined, Symbol(BES6)和BigInt(ES10)组成基本类型
【6月更文挑战第25天】JavaScript有7个数据类型:Number, String, Boolean, Null, Undefined, Symbol(BES6)和BigInt(ES10)组成基本类型,而Object包括Array、Function等是引用类型。Objects可以包含键值对,Array是特殊的Object。Functions也是对象。`null`和`undefined`被视为特殊的原始值。
17 1
|
22天前
|
JavaScript 前端开发
javaScript数据类型代码详细解读
javaScript数据类型代码详细解读
12 1
|
10天前
|
存储 JavaScript 前端开发
js【详解】数据类型原理(含变量赋值详解-浅拷贝)
js【详解】数据类型原理(含变量赋值详解-浅拷贝)
11 0
|
10天前
|
JavaScript
JS字符串数据类型转换,字符串如何转成变量,+号只要有一个是字符串,就会把另外一个转成字符串,- * / 都会把数据转成数字类型,数字型控制台是蓝色,字符型控制台是黑色,
JS字符串数据类型转换,字符串如何转成变量,+号只要有一个是字符串,就会把另外一个转成字符串,- * / 都会把数据转成数字类型,数字型控制台是蓝色,字符型控制台是黑色,
|
1月前
|
存储 JavaScript 前端开发
JavaScript基础-数据类型与转换
【6月更文挑战第11天】本文介绍了JavaScript的核心概念——数据类型和转换机制。JavaScript包含六种原始类型(Number, String, Boolean, Undefined, Null, Symbol)和一种复合类型(Object)。文章讨论了特殊值(NaN, Infinity)及其易错点,如误判NaN和null与undefined的混淆。此外,还阐述了隐式与显式类型转换,提醒开发者注意非数字字符串转Number和空字符串转Boolean时的陷阱。理解这些概念有助于编写更健壮的代码。
|
12天前
|
存储 前端开发 JavaScript
|
12天前
|
JavaScript 前端开发 安全
JavaScript数据类型与类型判断
【7月更文挑战第1天】JavaScript基础涉及多种数据类型,如字符串、数字、布尔值、undefined、null、Symbol和BigInt(ES新特性)。对象、数组和函数属于引用类型。类型判断可通过typeof(不准确判断null和Array)、instanceof(检查原型链)和Object.prototype.toString方法。理解这些对编写健壮的代码至关重要。
11 0
|
14天前
|
存储 JavaScript 前端开发
JavaScript 数据类型
JavaScript 数据类型
11 0