es6总结——数值扩展、对象方法扩展

数值扩展

1、Number.EPSILON是JavaScript 中表示最小精度   EPSILON属性值接近于2.2204460492503130808472633361816E-16   主要用在浮点数运算上

      function equal(a, b) {
        if (Math.abs(a - b) < Number.EPSILON) {
          return true;
        } else {
          return false;
        }
      }

      console.log(equal(0.1 + 0.2, 0.3));     //true

2、二进制和八进制

      let b = 0b1010;  //二进制 10
      let o = 0o777;   //八进制 511
      let d = 100;   //十进制100
      let x = 0xff;   //十六进制 255

3、Number.isFinite 检测一个数值是否为有限数


      console.log(Number.isFinite(100));  //true

      console.log(Number.isFinite(100 / 0));  //false

      console.log(Number.isFinite(Infinity));  //false

4、Number.isNaN检测数值是否为NaN

      console.log(Number.isNaN(100));  //FALSE

5、Number.parseInt  Number.parseFloat字符串转整数

      console.log(Number.parseInt("5211314lloovvee"));   //5211314

      console.log(Number.parseFloat("3.1415926啦啦啦"));   //3.1415926

6、Number.isInteger判断一个数是否为整数


      console.log(Number.isInteger(5));  //true

      console.log(Number.isInteger(5.55));  //false

7、Math.trunc将数字的小数部分抹掉

      console.log(Math.trunc(3.5555));  //3

8、Math.sign判断一个数到底为整数 负数 还是零

      console.log(Math.sign(100));  //1
      console.log(Math.sign(0));   //0
      console.log(Math.sign(-2000));   //-1

对象方法扩展

1、Objext.is判断两个值是否完全相等


      console.log(Object.is(120, 120));  //true
      console.log(Object.is(NaN, NaN));  //true
      console.log(Object.is(11, 111));  //false

2、Objext.assign对象合并


      const config1 = {
        host: "localhost",
        port: 3306,
        name: "root",
        pass: "root",
        test: "test",
      };

      const config2 = {
        host: "http://atguigu.com",
        port: 33060,
        name: "atguigu.com",
        pass: "iloveyou",
        test2: "test2",
      };
      console.log(Object.assign(config1, config2));

      const drink = {
        name: "奶茶",
      };
      const brand = {
        naicha: ["一点点", "coco", "蜜雪冰城"],
      };

      Object.setPrototypeOf(drink, brand);
      console.log(Object.getPrototypeOf(drink));
      console.log(drink);

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ES6 引入了一些数值扩展,其中包括了新的数值类型(如二进制和八进制)、新的数学方法和常量。 1. 二进制和八进制 在 ES6 中,我们可以使用 `0b` 或 `0B` 前缀来表示二进制数,使用 `0o` 或 `0O` 前缀来表示八进制数。例如: ```javascript let binary = 0b1010; // 二进制的 10 let octal = 0o777; // 八进制的 511 ``` 2. Number.isFinite() `Number.isFinite()` 方法用于检查一个数值是否为有限数。与全局的 `isFinite()` 函数不同的是,`Number.isFinite()` 不会将非数值转换为数值。例如: ```javascript Number.isFinite(Infinity); // false Number.isFinite(-Infinity); // false Number.isFinite(NaN); // false Number.isFinite(123); // true ``` 3. Number.isNaN() `Number.isNaN()` 方法用于检查一个数值是否为 NaN。与全局的 `isNaN()` 函数不同的是,`Number.isNaN()` 只有在参数是数值且等于 NaN 时才返回 true。例如: ```javascript Number.isNaN(NaN); // true Number.isNaN('hello'); // false Number.isNaN(123); // false ``` 4. Number.parseInt() `Number.parseInt()` 是 `parseInt()` 的一个新的方法,它将字符串转换为整数,并且只接受数字作为字符串的参数。例如: ```javascript Number.parseInt('123'); // 123 Number.parseInt('123.45'); // 123 Number.parseInt('hello'); // NaN ``` 5. Number.parseFloat() `Number.parseFloat()` 是 `parseFloat()` 的一个新的方法,它将字符串转换为浮点数,并且只接受数字作为字符串的参数。例如: ```javascript Number.parseFloat('3.14'); // 3.14 Number.parseFloat('3.14hello'); // 3.14 Number.parseFloat('hello'); // NaN ``` 6. Number.MAX_SAFE_INTEGER 和 Number.MIN_SAFE_INTEGER `Number.MAX_SAFE_INTEGER` 和 `Number.MIN_SAFE_INTEGER` 属性分别表示 JavaScript 中最大的安全整数和最小的安全整数。例如: ```javascript Number.MAX_SAFE_INTEGER; // 9007199254740991 Number.MIN_SAFE_INTEGER; // -9007199254740991 ``` 7. Number.isSafeInteger() `Number.isSafeInteger()` 方法用于检查一个数值是否为安全整数。安全整数是指符合以下两个条件的整数: - 在 JavaScript 中能够精确表示。 - 绝对值不大于 `Number.MAX_SAFE_INTEGER`。 例如: ```javascript Number.isSafeInteger(123); // true Number.isSafeInteger(9007199254740992); // false,超出了安全整数范围 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值