资讯专栏INFORMATION COLUMN

javascript 的基本类型 和 与操作符结合时的类型转换

pcChao / 3341人阅读

摘要:的基本类型的基本类型和类型转换系统相较于其他语言例如来说可以说是非常混乱的这个是许多新手必定会遇到的坑首先有五种简单的基本类型和一种复杂的数据类型类型检测有两种方式和用来检测对象的原型链但有时候也会不好用比如不同里的检测对于已经实现了方法的

javascript 的基本类型

javascript的基本类型和类型转换系统相较于其他语言例如 Java 来说可以说是非常混乱的.这个是许多新手必定会遇到的坑.首先javascript 有五种简单的基本类型(undefined,null,Number,Boolean,String).和一种复杂的数据类型object.

类型检测有两种方式 typeof 和 instanceof .

instanceof用来检测对象的原型链. 但有时候 instanceof 也会不好用比如不同window.frames[0]里的 Array检测,对于已经实现了 toString 方法的类型,我们可以用Object.prototype.toString.call(obj) 来检测,得到结果类似[object Array].

typeof : 因为NaN属于 number 的一种所以 typeof NaN === "number" ; 在javascript 里 Object,String等都是一种构造函数,所以 typeof Object === "function",typeof String === "function".
typeof 所有的检测结果如下:

Type Result
Undefined "undefined"
Null "object" (see below)
Boolean "boolean"
Number "number"
String "string"
Symbol (new in ECMAScript 2015) "symbol"
Host object (provided by the JS environment) Implementation-dependent
Function object (implements [[Call]] in ECMA-262 terms) "function"
Any other object "object"
与操作符结合后的 javascript 类型转换
    弱类型的 javascript 的许多操作符会自动类型转换,很多时候转换后的
    结果会让人吃惊.下面我们来总结一下:
1. 尝试将两个变量转换为数值(调用 Number())的操作符 :一元操作符 ++,--;乘性操作符 *,
    Number的转换规则是 
    1.1 如果是string:
        1.1.1 判断是否能转换为数值含有字母和其他非.符号的直接返回 
NaN ; 1.0 , .1 均可以转换为数值 ,.1.1含两个以上的不能转换为数值.
        1.1.2 能转换为数值的返回对应数值.
    1.2 如果是boolean:
        1.2.1 true 转换为0;
        1.2.2 false 转换为1;
    1.3 如果是 undefined: 转换为 NaN
    1.4 如果是 null 转换为 0
    1.5 如果是 Object var result = obj.valueof(); return Number(result) 如果得到 NaN,再调用 toString
2. 尝试将两个变量转换为布尔值: 布尔操作符 !;条件操作符 ? :
    Boolean的转换规则是:
    2.1 如果是string: 空字符串""返回 false ,其他返回 true.(注意 new String("") 属于对象)
    2.2 如果是number: 0返回 false,其他 true
    2.3 undefined 和 null 返回 false
    2.4 object : 返回true
3. 先判断是要转换为哪种基本类型,再做转换. 加性:+;条件>,<;非严格相等 == 3.1 加性 +,-
    3.1.1如果两个都是数值正常计算 infinity,-infinity 和 +0,-0 略过..
    3.1.2如果两个都是字符串拼接.
    3.1.3如果只有一个是字符串,将另一个转换为字符串.
    3.1.4如果有一个是对象,尝试转换为字符串
    3.1.5如果两个都不是字符串,且其中一个是数值,将另一个转换为数值.
    3.1.6其他情况都是 NaN
3.2 条件 >,<
    3.2.1两个都是数值,数值比较
    3.2.2两个都是字符串,字符编码比较 (注意 A
3.3 不严格相等 == 不同类型是
    3.3.1布尔值先转换为数值
    3.3.2一个是字符串,一个是数值.字符串转换为数值
    3.3.3对象调用 valueof(),再比较
    3.3.4 == 有 NaN,就为 fasle ;!= 有 NaN ,就为 true
    3.3.5 undefined == null ,undefined 和 null 不会转换为其他类型进行比较.
    
4.if 语句 使用 Boolean()

部分内容来源于 :

Javascript 高级程序设计, MDN和网络

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/85957.html

相关文章

  • Java 11 教程

    摘要:原文链接已于成功发布,不过目前绝大多数人在生产环境仍旧使用的是。这篇以案例为主的教程涵盖了从到的绝大多数重要的语法与特性。当编译器不能正确识别出变量的数值类型时,将不被允许使用。同步请求将会阻塞当前的线程,直到返回响应消息。 showImg(https://segmentfault.com/img/remote/1460000016575203); 原文链接:https://wangw...

    douzifly 评论0 收藏0
  • [JavaScript 随笔] 理解严格相等、非严格相等隐式类型转换

    摘要:显然,相等判断是基于数字比较的,而条件判断是基于布尔值。严格相等严格相等的逻辑相对简单粗暴,如果类型不同,就不考虑隐式转换了,直接为假。 JavaScript 中大概有这几种 类型: undefined null string boolean number object function 之所以在 类型 上加了双引号,是因为严格来说,null 的类型是 object。但本文讨论的主...

    rickchen 评论0 收藏0
  • 【连载】前端个人文章整理-从基础到入门

    摘要:个人前端文章整理从最开始萌生写文章的想法,到着手开始写,再到现在已经一年的时间了,由于工作比较忙,更新缓慢,后面还是会继更新,现将已经写好的文章整理一个目录,方便更多的小伙伴去学习。 showImg(https://segmentfault.com/img/remote/1460000017490740?w=1920&h=1080); 个人前端文章整理 从最开始萌生写文章的想法,到着手...

    madthumb 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<