我的编程空间,编程开发者的网络收藏夹
学习永远不晚

ECMAscrip新特性函数介绍

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

ECMAscrip新特性函数介绍

1.函数参数的默认值

1.1函数参数指定默认值

ECMAScript 2015中,允许为函数的参数添加默认值,将默认值直接写在参数的后面即可。

示例代码如下所示:


// 函数参数指定默认值
function fun(a = 1, b = 2) {
  console.log(a + b);
}
fun() // 3


值得注意的是:参数变量是默认声明的,所以不能用let或const再次声明, 否则会抛出异常。

还有就是默认参数的位置都是在参数列表的最后面,否则会引发歧义,该省略的参数不能省略,

如下代码示例:


// 默认参数的位置应该是在最后面
function fun(a = 1, b) {
  console.log(a, b);
}
// 调用函数,传递一个参数
fun(20); // 20 undefined


1.2与解耦赋值配合使用

参数默认值可以与解构赋值的默认值,结合起来使用。可以通过两种方式为其设置默认值。示例代码如下所示:


function fun([a, b = 5] = [3]) {
  console.log(a, b);
}
fun() // 3 5


1.3函数参数的作用域

一旦设置了参数的默认值,函数进行声明初始化时,参数会形成一个单独的作用域 。等到初始化结束,这个作用域就会消失。这种语法行为,在不设置参数默认值时,是不会出现的。

示例代码如下所示:


let x = 5

function fun(y = x) {
  x = 10
  console.log(y);
}
fun() // 5


2.rest参数

ECMAScript 2015引入rest参数(形式为...变量名),用于获取函数的多余参数,这样就不需要使用arguments对象了。rest 参数搭配的变量是一个数组,该变量将多余的参数放入数组中。

示例代码如下所示:


// 使用 arguments 对象最传入的参数求出最大值
function max1() {
  return Math.max.apply(null, arguments)
}

console.log(max1(1, 5, 6, 33, 65, 35, 15)); // 65

// 使用 rest 参数
function max2(...arg) {
  return Math.max(...arg)
}
console.log(max2(1, 5, 6, 33, 65, 35, 15)); // 65

3.箭头函数

3.1什么是箭头函数

ECMAScript 2015新增了箭头函数(又称胖剪头函数), 相比函数表达式具有较短的语法并以词法的方式绑定this 。箭头函数在大多数情况下都是匿名的。

箭头函数的语法结构如下所示:


// 基本语法结构
(参数1, 参数2, ..., 参数N) => {函数声明}
(参数1, 参数2, ..., 参数N) => 表达式(单一)
// 相当于:(参数1, 参数2, ..., 参数N) => {return 表达式}

// 当只有一个参数时,小可号是可选的
(参数) => {函数声明}
// 或者
参数 => {函数声明}

// 没有参数应该写一对小括号
() => {函数声明}

// 可以配合 rest 参数和默认参数
(参数1, 参数2, ...rest) => {函数声明}
(参数1, 参数2, ..., 参数N = 默认值N) => {函数声明}

箭头函数也可以为其定义函数名,语法结构如下所示:


let funName = (参数1, 参数2, ..., 参数N) => {函数声明}


示例代码如下所示:


let sum = (a, b) => {
  return a + b
}
console.log(sum(10, 20)); //30


3.2箭头函数的注意事项

箭头函数有几个使用注意点:

  • 函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。

示例代码如下所示:


// ES5 写法
let fun1 = function () {
  console.log(this.id);
}
// ES6 箭头函数写法
let fun2 = () => {
  console.log(this.id);
}

let obj1 = {
  id: 666,
  fun: fun1
}
let obj2 = {
  id: 666,
  fun: fun2
}
obj1.fun() // 666
obj2.fun() // undefined

由代码我们可以看出,普通函数的this是调用时确定的,而我们的箭头函数的this是在定义时就确定了的。

  • 不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。
  • 不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用rest参数代替。

4.函数的尾调用

尾调用是函数式编程的一个重要概念,本身非常简单,一句话就能说清楚,就是指某个函数的最后一步是调用另一个函数。

示例代码如下所示:


let x = (x) => {
  return 2 * x
}

let y = function (y) {
  return x(y)
}

console.log(y(20)); // 40

到此这篇关于ECMAscrip新特性之函数的扩展的文章就介绍到这了,更多相关ECMAscrip函数的扩展内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

ECMAscrip新特性函数介绍

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

SQL Server聚合函数新特性介绍

SQL Server 2017引入了一些新的聚合函数特性,让用户更轻松地处理数据并获得更好的性能。以下是一些主要的新特性:APPROX_COUNT_DISTINCT函数:这个函数可以用来估算一个列中不同值的数量,比如可以用来快速计算某个表中
SQL Server聚合函数新特性介绍
2024-08-03

Hibernate5新特性介绍

在hibernate5中,有了一些新的变动: 新引导 API Spatial/GIS 支持 Java 8 支持 扩展 AUTO id 生成支持 命名策略分离 属性转换器支持 更好的 “bulk id table” 支持
2023-05-31

Redis6的新特性介绍

本篇内容介绍了“Redis6的新特性介绍”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 前言Redis 6 主要的变化有:SSL、ACLs、
2023-06-15

Golang函数的高级特性介绍

高级 golang 函数特性:闭包:捕获周围作用域的变量,用于传递数据。变参函数:接受可变数量的参数。匿名函数:未命名,一次性回调或闭包。高阶函数:接收或返回函数的参数。泛型:通用函数,适用于不同数据类型(go 1.18 引入)。Golan
Golang函数的高级特性介绍
2024-04-15

Redis 6.0 新特性 ACL 介绍

redis 6.0 acl 介绍 Redis 6.0 新特性 ACL 介绍Intro在 Redis 6.0 中引入了 ACL(Access Control List) 的支持,在此前的版本中 Redis 中是没有用户的概念的,其实没有办法很好的
Redis 6.0 新特性 ACL 介绍
2022-03-30

JDK8新特性详细介绍

函数式编程面向对象强调“一切皆对象”,如果想要做事情,必须要找到对象来做。函数式编程思想强调“做什么”,而不是“怎么做”。普通的开启线程// 匿名内部类对象Runnable task = new Runnable() { @Override pub
JDK8新特性详细介绍
2021-05-08

AnalyticDB for PostgreSQL 6.0 新特性介绍

阿里云 AnalyticDB for PostgreSQL 为采用MPP架构的分布式集群数据库,完备支持SQL 2003,部分兼容Oracle语法,支持PL/SQL存储过程,触发器,支持标准数据库事务ACID。ADB PG通过行存储、列存储
2023-06-03

jdk1.5、1.6、1.7新特性详细介绍

JDK 1.5(也称为Java 5)的新特性包括:1. 泛型:引入了泛型,使得可以在编译时检查和强制类型安全的容器对象。2. 自动装箱和拆箱:自动将基本类型的值和对应的包装类对象进行相互转换。3. 增强for循环:简化了对数组和集合的遍历。
2023-08-25

Python3.8 特性介绍

简介海象表达式 :=仅位置参数 /f-strings 说明符 =启动异步 REPLunittest 支持异步简介Python3.8 已经发布了, 官方文档看这里What’s New In Python 3.8.介绍一些 Python3.8
2023-01-31

编程热搜

目录