阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

lodash里to系列之将数据转换成数字类型实现示例详解

85次阅读
没有评论

共计 3088 个字符,预计需要花费 8 分钟才能阅读完成。

导读 这篇文章主要为大家介绍了 lodash 里 to 系列之将数据转换成数字类型实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
正文

在 lodash 里的 to 系列里,将目标数据转换为数字类型的数据的方法,包括了 toNumber 方法、toFinit 方法、toInteger 方法,toSafeInteger 方法,下面来看看各个方法的使用和实现。

toNumber

toNumber 方法主要是将参数 value 转换为一个数字类型。

使用如下:

toNumber(3.2)
// => 3.2
toNumber(Number.MIN_VALUE)
// => 5e-324
toNumber(Infinity)
// => Infinity
toNumber('3.2')
 // => 3.2

toNumber 方法在实现上借助了内部封装的 is 系列方法,主要是 isObject 方法和 isSymbol 方法。

实现上借助 typeof,具体处理如下:

  • 对于数据类型直接返回参数。
  • 对于 symbol 类型直接返回 NaN。
  • 对于对象类型,分两种情况处理。
  • 如果参数原型链上存在 valueOf 方法,直接调用其返回结果供后续处理。
  • 如果参数原型链上不存在 valueOf 方法,直接转换成字符串类型供后续处理。
  • 对于非字符串类型的,调用隐式转换。
  • 对于其他类型的,会进行正则匹配处理数据格式,reTrim 是去除空格,reIsBadHex 是去除十六进制,reIsBinary 是去除二进制,reIsOctal 是去除八进制。
  • 对于二进制和八进制的字符串会调用原生的 parseInt 方法将参数转换为相应的进制数。而对于十六进制则返回 NaN,否则调用隐式转换。
  • 源码如下:

    import isObject from './isObject.js'
    import isSymbol from './isSymbol.js'
    const NAN = 0 / 0
    const reTrim = /^\s+|\s+$/g
    const reIsBadHex = /^[-+]0x[0-9a-f]+$/i
    const reIsBinary = /^0b[01]+$/i
    const reIsOctal = /^0o[0-7]+$/i
    const freeParseInt = parseInt
    function toNumber(value) {if (typeof value === 'number') {return value}
      if (isSymbol(value)) {return NAN}
      if (isObject(value)) {const other = typeof value.valueOf === 'function' ? value.valueOf() : value
        value = isObject(other) ? `${other}` : other
      }
      if (typeof value !== 'string') {return value === 0 ? value : +value}
      value = value.replace(reTrim, '')
      const isBinary = reIsBinary.test(value)
      return (isBinary || reIsOctal.test(value))
        ? freeParseInt(value.slice(2), isBinary ? 2 : 8)
        : (reIsBadHex.test(value) ? NAN : +value)
    }
    toFinit

    toFinit 方法主要是将参数 value 转换为一个有限的数字。

    使用如下:

    toFinite(3.2)
    // => 3.2
    toFinite(Number.MIN_VALUE)
    // => 5e-324
    toFinite(Infinity)
    // => 1.7976931348623157e+308
    toFinite('3.2')
    // => 3.2

    toFinit 方法实现上借助 toNumber 方法,具体处理如下:

  • 对于不存在的参数会直接返回参数,0 的话返回 0。
  • 其次调用 toNumber 方法转换参数,再通过 if 判断匹配 INFINITY 值,将其返回对应的 MAX_INTEGER。
  • 源码如下:

    import toNumber from './toNumber.js'
    const INFINITY = 1 / 0
    const MAX_INTEGER = 1.7976931348623157e+308
    function toFinite(value) {if (!value) {return value === 0 ? value : 0}
      value = toNumber(value)
      if (value === INFINITY || value === -INFINITY) {
        const sign = (value 
    
    toInteger

    toInteger 方法主要是将参数 value 转换为一个整数。

    使用如下:

    toInteger(3.2)
    // => 3
    toInteger(Number.MIN_VALUE)
    // => 0
    toInteger(Infinity)
    // => 1.7976931348623157e+308
    toInteger('3.2')
    // => 3

    实现上借助 toFinite 方法,首先调用 toInteger 方法将参数转换为有限的值,然后通过取模操作获取小数部分,然后取差值。

    源码如下:

    import toFinite from './toFinite.js'
    function toInteger(value) {const result = toFinite(value)
      const remainder = result % 1
      return remainder ? result - remainder : result
    }
    export default toInteger
    toSafeInteger

    toSafeInteger 方法主要是将参数 value 转换为安全整数,安全整数可以用于比较和准确的表示。

    使用如下:

    toSafeInteger(3.2)
    // => 3
    toSafeInteger(Number.MIN_VALUE)
    // => 0
    toSafeInteger(Infinity)
    // => 9007199254740991
    toSafeInteger('3.2')
    // => 3

    toSafeInteger 方法在实现上主要通过 toInteger 方法,同样的,对于不存在的参数直接返回参数,而 0 则返回 0。对于小于最小安全数 MAX_SAFE_INTEGER 则返回 MAX_SAFE_INTEGER,值都将限制在 [-MAX_SAFE_INTEGER,MAX_SAFE_INTEGER] 的区间。

    源码如下:

    import toInteger from './toInteger.js'
    const MAX_SAFE_INTEGER = 9007199254740991
    function toSafeInteger(value) {if (!value) {return value === 0 ? value : 0}
      value = toInteger(value)
      if (value  MAX_SAFE_INTEGER) {return MAX_SAFE_INTEGER}
      return value
    }
    export default toSafeInteger
    小结

    本篇章我们了解了 toNumber、toFinit、toInteger 以及 toSafeInteger 四个方法,在实现上依次借助调用实现。

    toNumber 方法是其他方法的核心,其他方法是 toNumber 方法的拓展。toNumber 方法的核心是 isObject 和 isSymbol 两个判断方法。

    阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

    腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

    代金券:在阿里云专用满减优惠券

    正文完
    星哥玩云-微信公众号
    post-qrcode
     0
    星锅
    版权声明:本站原创文章,由 星锅 于2024-07-24发表,共计3088字。
    转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
    【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
    阿里云-最新活动爆款每日限量供应
    评论(没有评论)
    验证码
    【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中