浅谈javascript中的数据类型转换
1、把其他的数据类型转换为number类型
Number()->严格
parseFloat/parseInt ->非严格
isNaN(value) 如果value值不是数字类型的,它是首先调用Number转换为数字类型然后在判断是否为有效的数字
例如:
Number("12px"); ->NaN
parseInt("12px"); ->12
isNaN("12"); ->false
规律:
1)把布尔类型转换为数字的话 true->1 false->0
2)把null/undefined转换为数字 null->0 undefined->NaN 10+null=10 10+undefined=NaN
3)把[]转换为数字 首先调用数组的toString方法把[]->"",然后在使用Number方法把""->0
2、把其他的数据类型转换为布尔类型
Boolean
!!
! 先转换为布尔类型,然后在取反
例如:
!!1->true
!!0->false
![]->false !![]->true
规律:
只有0、NaN、null、undefined、""这五个转换为布尔类型的时候是false,其余的转换完成都是true
特殊情况:
如果你的条件判断中只是单独的一个值,它是首先把1转换布尔类型(->true),在判断是真还是假,如果是真条件成立,反之条件不成立
if (1) { } if ("3px" * 3) {//->条件不成立 "3px" * 3=NaN ->false } if ("3px" + 3) {//->条件成立 "3px" + 3="3px3" ->true }
"+"在JS中不仅仅是数学运算,遇到字符串的时候属于字符串拼接
"-、*、/"在JS中只能是数学运算,遇到不是number类型的要强制转换为number进行数学性运算
3、两个值进行比较(==比较的,===比较数据类型不一样不会进行默认的转换),如果左右两边的数据类型不一样,我们需要遵循一套法则,进行默认的数据类型转换
value1==value2
1)对象==对象 比较的是自己存储的内存地址,如果内存地址不一样就不相等 []==[]->false 每一个空数组都是一个单独的内存地址
2)对象==字符串 调用toString方法,将对象转换为字符串 []==""->true
3)对象==布尔 对象转换为数字(toString-Number),布尔也转换为数字(true->1 false->0)
[]==false ->true []->0 false->0 0==0->true
![]==false -> ![]先把空数组转换为布尔类型然后在取反->false false==false->true
4)对象==数字 对象转换为数字 []==0->true []==1->false
5)字符串==布尔 两者都转换为数字 "3"==true->false "1"==true->true
6)字符串==数字 字符串转换为数字 ""==0->true
7)布尔==数字 布尔转换为数字 true==1->true true==2->false
8)null==undefined ->true null===undefined ->false
null/undefined和其他的任何值都不相等 null==0->false
9)NaN==NaN ->false NaN和任何的值(包括自己)都不相等
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持PHP中文网!
更多浅谈javascript中的数据类型转换相关文章请关注PHP中文网!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

Python和JavaScript开发者的薪资没有绝对的高低,具体取决于技能和行业需求。1.Python在数据科学和机器学习领域可能薪资更高。2.JavaScript在前端和全栈开发中需求大,薪资也可观。3.影响因素包括经验、地理位置、公司规模和特定技能。

如何在JavaScript中将具有相同ID的数组元素合并到一个对象中?在处理数据时,我们常常会遇到需要将具有相同ID�...

学习JavaScript不难,但有挑战。1)理解基础概念如变量、数据类型、函数等。2)掌握异步编程,通过事件循环实现。3)使用DOM操作和Promise处理异步请求。4)避免常见错误,使用调试技巧。5)优化性能,遵循最佳实践。

实现视差滚动和元素动画效果的探讨本文将探讨如何实现类似资生堂官网(https://www.shiseido.co.jp/sb/wonderland/)中�...

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

深入探讨console.log输出差异的根源本文将分析一段代码中console.log函数输出结果的差异,并解释其背后的原因。�...
