位置: 编程技术 - 正文

JavaScript隐式类型转换(js中的隐式类型转换)

编辑:rootadmin

推荐整理分享JavaScript隐式类型转换(js中的隐式类型转换),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js隐式函数,js隐式类型转化的方法,jsp隐式对象,js隐式类型,js隐式类型,js隐士类型转换,js隐士类型转换,js隐式类型,内容如对您有帮助,希望把文章链接给更多的朋友!

JavaScript的数据类型是非常弱的(不然不会叫它做弱类型语言了)!在使用算术运算符时,运算符两边的数据类型可以是任意的,比如,一个字符串可以和数字相加。之所以不同的数据类型之间可以做运算,是因为JavaScript引擎在运算之前会悄悄的把他们进行了隐式类型转换的,如下是数值类型和布尔类型的相加:

结果是一个数值型!如果是在C或者Java环境的话,上面的运算肯定会因为运算符两边的数据类型不一致而导致报错的!但是,在JavaScript中,只有少数情况下,错误类型才会导致出错,比如调用非函数,或者读取null或者undefined的属性时,如下:

多数情况下,JavaScript都不会出错的,而是自动的进行相应的类型转换。比如-, *, /,和%等算术运算符都会把操作数转换成数字的,但是“+”号就有点不一样了,有些情况下,它是算术加号,有些情况下,是字符串连接符号,具体的要看它的操作数,如下:

但是,如果字符串和数字相加,会是怎样的结果呢?JavaScript会自动把数字转换成字符的,不管数字在前还是字符串在前,如下:

字符串和数字相加结果是字符串,字符串和数字相加结果是字符串,字符串和数字相加结果是字符串,重要的事情说三遍!!!!!!

此外,需要注意的是,“+”的运算方向是从左到右的,如下:

这与下面是等价的:

相比之下,下面的结果是不一样的:

但是,隐式类型转换,有时候,会隐藏一些错误的,比如,null会转换成0,undefined会转换成NaN。需要注意的是,NaN和NaN是不相等的(这是由于浮点数的精度决定的),如下:

虽然,JavaScript提供了isNaN来检测某个值是否为NaN,但是,这也不太精确的,因为,在调用isNaN函数之前,本身就存在了一个隐式转换的过程,它会把那些原本不是NaN的值转换成NaN的,如下:

上面代码,我们使用isNaN来测试后,发现字符串,undefined,甚至对象,结果都返回真!!!但是,我们总不能说他们也是NaN吧?总而言之,得出的结论是:isNaN检测NaN并不可靠!!!

JavaScript隐式类型转换(js中的隐式类型转换)

幸运的是,有一种可靠的并且准确的方法可以检测NaN。我们都知道,只有NaN是自己不等自己的,那么,我们就以使用不等于号(!==)来判断一个数是否等于自身,从而,可以检测到NaN了,如下:

我们也可以把这种模式定义成一个函数,如下:

OK,NaN的检测方法就是这么简单,我们下面继续讨论对象的隐式转换!

对象是可以转换成原始值的,最常见的方法就是把它转换成字符串,如下:

对象转换成字符串是调用了他的toSting函数的,你可以手动的调用它来检测一下:

类似的,对象也是可以转换成数字的,他是通过valueOf函数的,当然,你也是可以自定义这个valueOf函数的,如下:

如果,一个对象同时存在valueOf方法和toString方法,那么,valueOf方法总是会被优先调用的,如下:

但是,多数情况下,这都不是我们想要的,一般的,尽可能使valueOf和toString表示的值相同(尽管类型可以不同)。

最后一种强制类型转换,我们常常称之为“真值运算”,比如,if, ||, &&,他们的操作数不一定是布尔型的额。JavaScript会通过简单的转换规则,将一些非布尔类型的值转换成布尔型的。大多数的值都会转换成true,只有少数的是false,他们分别是:false, 0, -0, ”", NaN, null, undefined,因为存在数字和字符串以及对象的值为false,所以,直接用真值转换来判断一个函数的参数是否传进来了,这是不不太安全的。比如,有一个可以具有默认值得可选参数的函数,如下:

这个函数会忽略任何的真值为假的参数的,包括0,-0;

检测undefined的更加准确的方法是用typeof操作:

这种写法,可以区分开0和undefined的:

另外一种方法是利用参数跟undefined作比较,如下:

总结:

1. 类型错误有可能会被类型转换所隐藏。

2. “+”既可以表示字符串连接,又可以表示算术加,这取决于它的操作数,如果有一个为字符串的,那么,就是字符串连接了。

3. 对象通过valueOf方法,把自己转换成数字,通过toString方法,把自己转换成字符串。

4.具有valueOf方法的对象,应该定义一个相应的toString方法,用来返回相等的数字的字符串形式。

5.检测一些未定义的变量时,应该使用typeOf或者与undefined作比较,而不应该直接用真值运算。

关于JavaScript隐式类型转换就给大家介绍到这里,希望对大家有所帮助!

dedecms页面如何获取会员状态的实例代码 dedecms页面如何获取会员状态的实例代码前几天做了一个企业网站,导航栏增加了会员信息,如:已登陆:显示:欢迎会员名未登陆显示:请登录代码如

原生JS实现平滑回到顶部组件 返回顶部组件是一种极其常见的网页功能,需求简单:页面滚动一定距离后,显示返回顶部的按钮,点击该按钮可以将滚动条滚回至页面开始的位置。

通过隐藏iframe实现无刷新上传文件操作 其实在ajax出现之前,web应用也可以是无刷新的,那时大多通过IFrame来做到这一点。当然Ajax出现之后,人们一窝蜂地投奔Ajax的阵营了,iFrame就乏人问津

标签: js中的隐式类型转换

本文链接地址:https://www.jiuchutong.com/biancheng/377506.html 转载请保留说明!

上一篇:JavaScript正则表达式匹配 div style标签(js正则表达式gi)

下一篇:dedecms页面如何获取会员状态的实例代码(dedecms建站操作)

  • 文化建设费征收依据
  • 消费卡预付卡能入账吗
  • 行政事业性收费票据
  • 电子税务局税种核定怎么操作
  • 房产继承是不是谁照顾谁的
  • 存货内部交易抵消通俗讲解
  • 商业发票和形式发票英文
  • 公司回购房产契税谁交
  • 个人所得税免征项目有哪些
  • 租客一次性支付一年租金需要交个税吗
  • 开增值税票需要合同吗
  • 应交税费应交堤围费的税率多少?
  • 所得税退税需要多久
  • 车辆保险车船税每年交多少
  • 事业单位什么情况下可以提前退休
  • 坏账的计提和发生分录
  • 酒店优惠券财务如何记账?
  • 用于采购的借款账户
  • 价外收入是什么意思
  • 简易征收发票能抵扣吗
  • 社保增加人员网上申报
  • 收到银行承兑汇票后,如何取钱
  • php过滤emoji
  • 苹果mac os x 10.7.5
  • kb4577266补丁
  • 补充协议是否缴纳印花税
  • php常用设计模式(大总结)
  • 出纳借方
  • 境外汇款所得税缴纳规定
  • 哪些发票不可以通过数电平台开具
  • hue环境搭建
  • Symfony2 session用法实例分析
  • 房地产企业如何计算土地使用税
  • 什么是分红型保险?
  • openai发布企业版
  • 其他权益工具投资公允价值变动怎么计算
  • 增值税纳税申报表怎么填
  • 账面未分配利润等于净利润?
  • 开基本户一定要法人身份证吗
  • 汇算清缴期间费用保险费是什么
  • 织梦如何使用
  • c语言中使用指针的好处
  • python如何提取文件中的数据
  • 哪个命令可以对mysql数据库做完全备份
  • 企业征收所得税会计分录
  • 银行承兑汇票到期未承兑怎么办
  • 奖励促销策略
  • 过户车子需要带什么证件
  • 固定资产计提折旧的会计科目
  • 免税发票怎么抵扣
  • 年底需要结转的会计科目
  • 企业支付宝问题解决
  • 建账的过程包括哪些内容
  • 设置账簿的依据
  • mysql数据库开发技术
  • 数据库的常用语句
  • 电脑太慢了怎么解决
  • centos页面
  • 怎么清理win7
  • WARNING: /tmp: File system full, swap space limit exceeded的解决办法
  • win7系统点击桌面图标闪退
  • linux关闭sh
  • cocos做游戏
  • Unity3D游戏开发标准教程
  • android中的布局分为6种,分别是
  • python如何搭建环境
  • 深入理解python特性 pdf
  • cocos2dx 不规则按钮的实现
  • Node.js中的什么模块是用于处理文件和目录的
  • python对excel操作真的有提高吗
  • u3d中文版本
  • vue复用node_module
  • Android 判断是否打开了微信
  • javascript构造函数可继承父类的构造函数
  • jquery的哪个方法可以绑定mouseover
  • Python中使用装饰器来优化尾递归的示例
  • 如何判断python列表长度
  • 航天金税软件怎么下载
  • 支部组织生活会流程
  • 工会经费支出审批制度
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设