ES6 函数的扩展

箭头函数

  function method(){

     }
    let methods=()=>{ //无参

    }

    let methods=a=>{//有参a

    }

    let methods=(a,b)=>{//有参a,b

 }

 let data=()=>{
     //执行代码
      return true;
 }

 //let data=()=>true;

箭头函数的特点:保持上下文this指针一致

console.log(this);//window
            let obj = {
                sleep: function () {
                    console.log(this);//obj
                    setTimeout(() => {
                        console.log(this);//obj
                    }, 1000);
                    // setTimeout(function (){
                    //     console.log(this);//window
                    //     //如果要使用obj

                    // }, 1000);
                }
            }
            obj.sleep();

函数简写

            //对象上的函数
            let stu = {
                eat: function () {

                },
                work() {
                    return {

                    }
                }
            }

匿名函数变箭头

            //对象上的 函数直接简写
            //es6中的函数  可以进行参数的默认值
            let stus = (x = 2, y = 10) => {
                console.log(x, y);//2,10
            }

指定了默认值以后,函数的length属性,将返回没有指定默认值的参数个数。也就是说,指定了默认值后,length属性将失真

console.log(stus.length); //返回函数没有指定默认值个数 0

如果设置了默认值的参数不是尾参数,那么length属性也不再计入后面的参数了

           let stus = (x=2,y,z) => {
            console.log(x,y,z);//2 undefined undefined
            }
            stus();
            console.log(stus.length);//0
            let stus = (x,y=2,z) => {
            console.log(x,y,z);//undefined 2 undefined
            }
            stus();
            console.log(stus.length);//1

函数和解构赋值搭配使用

对象解构:

      let fun3 = ({ a6, b6 }) => {
            console.log(a6, b6);//1 2
       }

        fun3({ a6: 1, b6: 2 });

结构别名:

            let a=1;
            let b=2;
            let [a1, b1] = [2, 1];
            console.log(a1, b1);

函数和解构赋值搭配使用

   let [a,...b]=[1,2,3,4];
   a=1
   b=[2,3,4]
   let fun=([a,...b])=>{
       console.log(a,b); //1 234
   }
  fun([1,2,3,4]); 

rest 参数

获取函数多余的参数 使用是 扩展运算符 …

function add(...values) {
  let sum = 0;

  for (var val of values) {
    sum += val;
  }

  return sum;
}

add(2, 5, 3) // 10

函数的name属性

console.log(fun3.name)//fun3

箭头函数嵌套问题

let fun5=()=>{
            console.log(this);//window
            return ()=>{
                console.log(this);
            }
        }
        fun5();
  • 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、付费专栏及课程。

余额充值