ES6函数的扩展

目录

一. 变量的解构赋值

1.涵义

2.数组的解构赋值

3.对象的解构赋值 

二. 函数的扩展 

 1.函数参数的默认值

 2.rest参数

三. 箭头函数

1.用法

2.注意点 


一. 变量的解构赋值

1.涵义

按照一定的模式,从数组或对象中提取值,对变量进行赋值,这被称为解构(Destructruring)。

2.数组的解构赋值
  • 只要某种数据结构具有Iterator接口,都可以采用数组形式的解构赋值
  • 允许左边变量指定默认值。右边数据结构使用严格相等运算符(===),判断一个位置是否有值,只有当其成员严格相等于undefined,默认值才会生效。
3.对象的解构赋值 
  •  对象解构赋值的内部机制是,先找到同名属性,再赋值给对应的变量,真正被赋值的是后者,前者是模式。
  • 对象的解构赋值可以取到继承的属性
let { foo: baz } = { foo: 'aaa', bar: 'bbb' };
//实际是下面形式的简写
let { foo: foo, bar: bar } = { foo: 'aaa', bar: 'bbb' };

二. 函数的扩展 

 1.函数参数的默认值
  • 参数变量是默认声明的,所以不能用let或const再次声明
  • 参数默认值是惰性求值的
  • 使用参数默认值时,函数不能有同名参数
  • 当函数的参数是对象时,如果不为参数设置默认值,在调用函数时不能省略该参数,否则会报错
  • 定义默认值的参数,通常应该时函数的尾参数,这样实际调用该函数时才可以省略
  • 函数的length属性的含义是,预期传入的参数的个数,其不会计入设置了默认值的参数及其之后的参数
  • 一旦设置了参数的默认值,函数进行声明初始化时,参数会形成一个单独的作用域
// 参数变量默认声明
function foo(y = 5) {
  let y = 1; // error
  const y = 2; // error
}

// 设置了参数默认值,形成单独的作用域
let x = 1;

function f(y = x) {
  let x = 2;
  console.log(y);
}
f() // 1
 2.rest参数
  • rest参数(形式为...变量名) ,是一个数组,可获取函数的多余参数
  • rest参数后不能再有其他参数(即只能是最后一个参数),否则会报错
  • 函数的length属性,不包括rest参数

三. 箭头函数

1.用法
  • 使用箭头(=>)定义函数
  • 如果箭头函数不需要参数或需要多个参数,就使用圆括号代表参数部分
  • 如果箭头函数的代码块部分多余一条语句,就使用大括号将他们括起来
2.注意点 
  • 没有自己的this对象。内部this指向箭头函数定义时的上层作用域中的this
  • 不可以当作构造函数
  • 不可以使用arguments,该对象在函数体内不存在
  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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,超出了安全整数范围 ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值