最新公告
  • 欢迎您光临网站无忧模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 谈一下ES6中数据类型的定义及typeof类型检测,绝对有你不知道的部分

    正文概述 掘金(狸不开)   2021-08-05   506

    这是我参与8月更文挑战的第4天

    js中的数据类型

     原始值类型

    •  1. number:NaN[不是一个有效数字]、Infinity[无穷大的值]
    •  2. string
    • 3. boolean
    •  4. null
    •  5. undefined
    •  6. symbol
    •  7. bigint

    对象类型

    •  标准普通对象 object
    • 标准特殊对象 Array/Regexp/Date/Error/Math/ArrayBuffer/DataView/Set/Map。。。
    •  非标准特殊对象 Number/Sring/Boolean/Symbol/Bigint
    •  可调用对象 【实现了call方法】function

    symbol类型

    1.对象的唯一属性

     如果想要拿到Symbol()的值

    方法1
    let key = Symbol()
    let obj = {
        [key]: 100
    }
    console.log(obj[key]) 
    
    方法2
    let arr = Object.getOwnPropertySymbols(obj) //获得当前对象所有的Symbol属性
    arr.forEach(item => {
        console.log(obj[item])
    })
    

    2.宏观管理标识:保证标志的唯一性(vuex/redux)

    3.底层原理

    • Symbol.hasInstance
    • Symbol.iterator
    • Symbol.toPrimitive
    • Symbol.toStringTag
    • ......

    谈一下ES6中数据类型的定义及typeof类型检测,绝对有你不知道的部分

    typeof的语法

    typeof是一个运算符,有2种使用方式:typeof(表达式)和typeof 变量名,第一种是对表达式做运算,第二种是对变量做运算。

    数据类型检测

    •  1. typeof 运算符
    •  2. instanceof [本意:检测实例是否属于某类]
    •  3. constructor [本意:获取构造函数]
    •  4. Object.prototype.toString.call([value]) 检测数据类型
    •  5. Array.isArray([value]) 检测一个值是否为数组

    typeof[value]

    • 1. 返回[value]所属类型的字符串 例如'Number'/'String'...
    • 2. 不能检测null typeod null -> 'Object'
    • 3. 除可调用对象[函数]会返回'function' [不论是箭头函数、构造函数、生成器函数、普通函数都返回'function'] 其余的对象数据值返回的都是'Object'
    •  4. 检测一个未被申明的变量不会报错,返回undefined
    GetValue(val) [浏览器内部提供的方法C++],按照值存储的二进制进行检测
    •   + 对象 000 -> 函数实现了call,则返回'function' 没实现call返回'object'
    •   + null 000000 -> 没实现call返回'object'
    •   + undefined -2^30
    •   + 数字 -> 整数1 浮点数010
    •   + 字符串 -> 100
    •   + 布尔 -> 110
    typeof 检测数据类型还是很快的,检测原始值类型[除了null,还是很准确的]

    字面量:原始值

    let n = 10
    // 构造函数
    let m = new Number(10);
    let x = Object(10);
    // 不允许被new的
    new Symbol()  // Uncaught TypeError: Symbol is not a constructor
    new BigInt()
    
    最大安全数字:9007199254740991 超过这个数字进行运算就不准确了
    console.log(Number.MAX_SAFE_INTEGER,Number.MIN_SAFE_INTEGER)
    问题:服务器中有longInt 长整型这种值,如果把这样的值返回客户端,则客户端无法进行有效的处理
    [一般服务器都是以字符串的形式返回,但是字符串进行计算还是需要转换为数字才可以,还是不准确]

    9007199254740991n-1n 数字后面加n就是bigint类型 9007199254741000n.toString() =>返给服务器

    谈一下ES6中数据类型的定义及typeof类型检测,绝对有你不知道的部分

    前端路漫漫其修远兮,吾将上下而求索,一起加油,学习前端吧!


    下载网 » 谈一下ES6中数据类型的定义及typeof类型检测,绝对有你不知道的部分

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元