ES6扩展

方法说明
Number.isFinite() 判断一个值是不是有限的
Number.isNan() 判断一个值是不是NaN
Number() 类型转换
Numbar.parseInt() 将字符串转化为整数
Numbar.parseFloat() 将字符串转化为小数
Numbar.isInteger() 判断一个数是不是一个整数
Number.isSafeInteger() 判断是不是一个安全的数
Math.cbrt() 用于计算一个数的立方根
Math.trunc() 用于去除一个数的小数部分,返回整数

 

 1 1、如果参数类型不是数值,Number.isFinite一律返回false
 2 2、如果参数类型不是NaN,Number.isNaN一律返回false
 3 注:es5含有隐式转换,es6不含有隐式转换
 4 
 5 // es5
 6 isFinite(25) // true
 7 isFinite("25") // true
 8 // es6
 9 Number.isFinite(25) // true
10 Number.isFinite("25") // false
11 
12 // es5
13 isNaN(NaN) // true
14 isNaN("NaN") // true
15 // es6
16 Number.isNaN(NaN) // true
17 Number.isNaN("NaN") // false
18 Number.isNaN(1) // false
19 
20 3、Number.parseInt(), Number.parseFloat()
21 // ES5的写法
22 parseInt('12.34') // 12
23 parseFloat('123.45#') // 123.45
24 
25 // ES6的写法
26 Number.parseInt('12.34') // 12
27 Number.parseFloat('123.45#') // 123.45
28 
29 这样做的目的,是逐步减少全局性方法,使得语言逐步模块化。
30 Number.parseInt === parseInt // true
31 Number.parseFloat === parseFloat // true
32 
33 4、Number.isInteger()用来判断一个数值是否为整数
34 Number.isInteger(25) // true
35 Number.isInteger(25.1) // false
36 Number.isInteger(25.0) // true
37 // 如果参数不是数值,Number.isInteger返回false
38 Number.isInteger() // false
39 Number.isInteger(null) // false
40 Number.isInteger('15') // false
41 Number.isInteger(true) // false
42 
43 5、Number.isSafeInteger()则是用来判断一个整数是否落在这个范围之内
44 Number.isSafeInteger('a') // false
45 Number.isSafeInteger(null) // false
46 Number.isSafeInteger(NaN) // false
47 Number.isSafeInteger(Infinity) // false
48 Number.isSafeInteger(-Infinity) // false
49 
50 Number.isSafeInteger(3) // true
51 Number.isSafeInteger(1.2) // false
52 Number.isSafeInteger(9007199254740990) // true
53 Number.isSafeInteger(9007199254740992) // false
54 
55 Number.isSafeInteger(Number.MIN_SAFE_INTEGER - 1) // false
56 Number.isSafeInteger(Number.MIN_SAFE_INTEGER) // true
57 Number.isSafeInteger(Number.MAX_SAFE_INTEGER) // true
58 Number.isSafeInteger(Number.MAX_SAFE_INTEGER + 1) // false
59 
60 
61 6、Math.trunc方法用于去除一个数的小数部分,返回整数部分
62 Math.trunc(4.1) // 4
63 Math.trunc(4.9) // 4
64 Math.trunc(-4.1) // -4
65 Math.trunc(-4.9) // -4
66 Math.trunc(-0.1234) // -0
67 
68 // 对于非数值,Math.trunc内部使用Number方法将其先转为数值
69 Math.trunc('123.456') // 123
70 Math.trunc(true) //1
71 Math.trunc(false) // 0
72 Math.trunc(null) // 0
73 
74 // 对于空值和无法截取整数的值,返回NaN
75 Math.trunc(NaN);      // NaN
76 Math.trunc('foo');    // NaN
77 Math.trunc();         // NaN
78 Math.trunc(undefined) // NaN
79 
80 
81 7、Math.cbrt方法用于计算一个数的立方根
82 Math.cbrt(-1) // -1
83 Math.cbrt(0)  // 0
84 Math.cbrt(1)  // 1
85 Math.cbrt(2)  // 1.2599210498948734
86 对于非数值,Math.cbrt方法内部也是先使用Number方法将其转为数值
87 Math.cbrt('8') // 2
88 Math.cbrt('hello') // NaN
View Code

 

1、设置默认值

  • 回调里面使用箭头函数,this指向上级对象
  • 回调里面使用function,this指向当前对象
  •  1  // es5
     2  let fun = function(val){
     3     var val = val || 666;
     4     return val
     5  }
     6  console.log(fun())
     7   
     8  
     9  // es6
    10  let fun = (val=666) => {
    11      return val;
    12  }
    13  // 简写
    14  let fun = (val=666) => val;
    15  
    16  // 函数默认值的注意事项
    17  // 定义形参默认值,需要注意:先声明后使用,遵循声明变量的规则
    18  let fun = (val,val) => { // 报错
    19     console.log(val)
    20  }
    21  let fun = (val2 = 2,val1 = val2) => { 
    22     console.log(val1)
    23  }
    24  fun();
    25  
    26  
    27  // 设置形参后,函数内部的私有变量如果用let命令来声明变量,不得重复定义
    28  let fun = (val) => {  // 报错
    29      let val = 666;
    30      console.log(val)
    31  }
    32  fun(555);
    33  
    34  
    35  // 获取函数所有形参
    36  // es5
    37  let fun = function(){
    38     console.log(arguments); // 类数组
    39     [...arguments].forEach(item=>{ // 通过...把它转为一个数组
    40         console.log(item);
    41     })
    42  }
    43  fun(1,2,3,4,5)
    44  
    45  // es6
    46  // 箭头函数没有arguments对象
    47  // reset 参数返回一个实参的数组的集合
    48  let fun = (...reset) => {
    49      console.log(reset)
    50      reset.forEach(item=>{ 
    51         console.log(item);
    52     })
    53  }
    54  fun(1,2,3,4,5,6)
    55  

     

 

2、扩展运算符 ...

  • 可以展开一个数组

#3、伪逗号

  • es2017允许你去写一个逗号

 1 let obj = { 2 name:'zs', 3 age:18, 4 } 

 

4、数组的扩展

 1 1、扩展运算符
 2 // 将数组转化为数组项的参数系列
 3 let arr1 = [1,2,3,4];
 4 let arr2 = [...arr1];
 5 
 6 
 7 2. Array.from(arr)
 8 // 将类似数组、可以遍历对象(包括set map解构类型的数据) 转为数组
 9 ...arr 展开数组的每一项   [...arr] 转为一个数组
10 
11 
12 3、数组的空值/空位
13 let arr = new Array(5);
14 // 长度为5   a[0]为undefined
15 
16 
17 4、Array.of()  用来将一组参数序列转为数组,可以用来代替new Array()
18 let arr = Array.of(1,2,3,4,5);
19 console.log(arr)
20 // 不传参为空数组
21 
22 
23 5、Array.copyWithin(target,start,end)
24 用数组中的一些项,替换数组中的值
25 // target(必须): 要替换项的下标
26 // start(可选): 替换的起始下标
27 // end(可选): 替换的结束下标
28 let arr = [1, 4, 2, 5, 3, 2];
29 console.log(arr.copyWithin(0, 4))
30 // [ 3, 2, 2, 5, 3, 2 ]
31 
32 
33 6、Array.find()   返回满足条件的第一个项
34 let arr = [2,8,4,3];
35 let res = arr.find((item,index,array)=>{
36     return item>2;
37 })
38 console.log(res) // 8
39 
40 
41 7、Array.findIndex()   返回满足条件的第一个项下标
42 let arr = [2,8,4,3];
43 let res = arr.findIndex((item,index,array)=>{
44     return item==2;
45 })
46 console.log(res) // 0
47 
48 
49 8、Array.fill()  给数组填充相同的值
50 let arr = new Array(5);
51 arr.fill("mmd",2,3) 
52 // 2 是开始下标
53 // 3 是结束下标
54 
55 
56 9、去重 结合set实现数组去重
57 let arr = [1,2,3,4,5,2,1,3,4,4];
58 let res = new Set(arr);
59 console.log(res) // 转为一个类数组
60 let result = Array.from(res); // 转数组

5、this指向

1 构造器 === 构造函数
2 1、箭头函数不是一个构造器,不可以实例化
3 let fun = () => {
4     
5 }
6 new fun()  // 报错
7 
8 2、::  左边是一个对象  右边是一个方法

6、对象扩展

1 console.log(Object.is(123,'123')) // false
2 
3 
4 1、Object.assign()  默认是浅拷贝
5  // 3个参数是深度拷贝  Object.assign({},obj1,obj2)
6  // 2个参数是浅拷贝 Object.assign(obj1,obj2)
7  
8  有{}会生成新串   没有会替换原字符串

 

posted @ 2020-06-03 11:01  motian  阅读(138)  评论(0编辑  收藏  举报