ESnd 箭头函数综合指南

esnd 箭头函数综合指南

es6简介

ecmascript 2015,也称为 es6 (ecmascript 6),是对 javascript 的重大更新,引入了新的语法和功能,使编码更高效、更易于管理。 javascript 是最流行的 web 开发编程语言之一,es6 的改进大大增强了其功能。

本指南将涵盖 es6 中引入的重要功能,特别关注箭头函数,这是一种强大的新函数编写方式。

es6 的主要特性

1. let 和 const

es6 引入了两种新的变量声明方式:let 和 const。

let:声明一个块作用域变量,这意味着该变量仅在声明它的块内可用。

 let x = 10; if (true) {   let x = 2;   console.log(x); // 2 (inside block) } console.log(x); // 10 (outside block)

const:声明一个不能重新赋值的常量变量。然而,这并不会使变量不可变——用 const 声明的对象仍然可以更改其属性。

 const y = 10; y = 5; // error: assignment to constant variable. const person = { name: "john", age: 30 }; person.age = 31; // this is allowed.

2. 箭头函数

es6 最受关注的功能之一是箭头函数。它为编写函数提供了更短、更简洁的语法。

#### 语法比较:

传统函数 (es5):

   var add = function(x, y) {     return x + y;   };

箭头函数 (es6):

   const add = (x, y) => x + y;

以下是箭头函数的不同之处:

更短的语法:不需要写function关键字,如果函数只有一条语句,可以省略大括号{}。隐式返回:如果函数只包含一个表达式,则自动返回该表达式的结果。没有 this 绑定:箭头函数没有自己的 this,使得它们不适合对象方法。

单线箭头函数示例:

   const multiply = (a, b) => a * b;   console.log(multiply(4, 5)); // 20

箭头函数也可以不带参数使用:

   const greet = () => "hello, world!";   console.log(greet()); // "hello, world!"

对于多行函数,需要大括号{},并且返回语句必须明确:

   const sum = (a, b) => {     let result = a + b;     return result;   };

箭头函数和这个
一个重要的区别是箭头函数中的行为方式。与传统函数不同,箭头函数不绑定自己的 this — 它们从周围的上下文继承 this。

   const person = {     name: "john",     sayname: function() {       settimeout(() => {         console.log(this.name);       }, 1000);     }   };   person.sayname(); // "john"

在上面的示例中,settimeout 中的箭头函数从 sayname 方法继承了 this,它正确引用了 person 对象。

3. 解构赋值

解构允许我们从数组或对象中提取值,并以更简洁的方式将它们分配给变量。

对象解构:

   const person = { name: "john", age: 30 };   const { name, age } = person;   console.log(name); // "john"   console.log(age);  // 30

数组解构:

   const fruits = ["apple", "banana", "orange"];   const [first, second] = fruits;   console.log(first);  // "apple"   console.log(second); // "banana"

4. 展开和休息运算符 (…)

… 运算符可用于将数组扩展为单个元素或将多个元素收集到一个数组中。

扩展:将数组扩展为单个元素。

 const numbers = [1, 2, 3]; const newnumbers = [...numbers, 4, 5]; console.log(newnumbers); // [1, 2, 3, 4, 5]

rest:将多个参数收集到一个数组中。

 function sum(...args) {   return args.reduce((acc, curr) => acc + curr); } console.log(sum(1, 2, 3, 4)); // 10

5.承诺

promises 用于处理 javascript 中的异步操作。 promise 代表了一个可能现在、将来或永远不可用的值。

示例:

   const mypromise = new promise((resolve, reject) => {     settimeout(() => {       resolve("success!");     }, 1000);   });   mypromise.then(result => {     console.log(result); // "success!" after 1 second   });

在此示例中,promise 在 1 秒后解析,然后 then() 方法处理解析后的值。

6. 默认参数

在es6中,你可以为函数参数设置默认值。当未提供或未定义参数时,这非常有用。

示例:

   function greet(name = "guest") {     return `hello, ${name}!`;   }   console.log(greet());       // "hello, guest!"   console.log(greet("john")); // "hello, john!"

7. 字符串方法(包括()、startswith()、endswith())

向字符串添加了新方法,使常见任务变得更容易:

includes():检查字符串是否包含指定值。

 let str = "hello world!"; console.log(str.includes("world")); // true

startswith():检查字符串是否以指定值开头。

 console.log(str.startswith("hello")); // true

endswith():检查字符串是否以指定值结尾。

 console.log(str.endswith("!")); // true

8. 数组方法(find()、findindex()、from())

es6 引入了处理数组的新方法:

find():返回第一个满足条件的元素。

 const numbers = [5, 12, 8, 130, 44]; const found = numbers.find(num => num > 10); console.log(found); // 12

findindex():返回第一个满足条件的元素的索引。

 const index = numbers.findindex(num => num > 10); console.log(index); // 1 (position of 12 in the array)

9. 课程

es6 向 javascript 引入了类,它们是 javascript 现有的基于原型的继承的语法糖。类允许更清晰、更易于理解的面向对象编程。

示例:

   class Car {     constructor(brand, year) {       this.brand = brand;       this.year = year;     }     displayInfo() {       return `${this.brand} from ${this.year}`;     }   }   const myCar = new Car("Toyota", 2020);   console.log(myCar.displayInfo()); // "Toyota from 2020"

结论

es6 改变了 javascript,使其更高效、更易于使用。 箭头函数的引入简化了函数语法,而解构承诺扩展运算符等新功能 允许开发人员编写更清晰、更具表现力的代码。无论您是初学者还是高级开发人员,了解这些 es6 功能对于编写现代 javascript 至关重要。

通过掌握这些概念,您将能够更好地应对现实世界的编码挑战并构建高效、可扩展的 web 应用程序。

跟进 github 上的 arrow functions 项目

参考

https://www.w3schools.com/js/js_es6.asphttps://towardsdatascience.com/javascript-es6-iterables-and-iterators-de18b54f4d4https://developer.mozilla.org/en-us/docs/web/javascript/reference/functions/rest_parametershttps://developer.mozilla.org/en-us/docs/web/javascript/reference/functions/default_parametershttps://developer.mozilla.org/en-us/docs/web/javascript/reference/functions/arrow_functionshttps://developer.mozilla.org/en-us/docs/web/javascript/reference/statements

以上就是ESnd 箭头函数综合指南的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1492049.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 14:29:19
下一篇 2025年12月19日 14:29:29

相关推荐

  • HTML、CSS 和 JavaScript 中的简单侧边栏菜单

    构建一个简单的侧边栏菜单是一个很好的主意,它可以为您的网站添加有价值的功能和令人惊叹的外观。 侧边栏菜单对于客户找到不同项目的方式很有用,而不会让他们觉得自己有太多选择,从而创造了简单性和秩序。 今天,我将分享一个简单的 HTML、CSS 和 JavaScript 源代码来创建一个简单的侧边栏菜单。…

    2025年12月24日
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    000
  • 带有 HTML、CSS 和 JavaScript 工具提示的响应式侧边导航栏

    响应式侧边导航栏不仅有助于改善网站的导航,还可以解决整齐放置链接的问题,从而增强用户体验。通过使用工具提示,可以让用户了解每个链接的功能,包括设计紧凑的情况。 在本教程中,我将解释使用 html、css、javascript 创建带有工具提示的响应式侧栏导航的完整代码。 对于那些一直想要一个干净、简…

    2025年12月24日
    000
  • 布局 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在这里查看视觉效果: 固定导航 – 布局 – codesandbox两列 – 布局 – codesandbox三列 – 布局 – codesandbox圣杯 &#8…

    2025年12月24日
    000
  • 隐藏元素 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看隐藏元素的视觉效果 – codesandbox 隐藏元素 hiding elements hiding elements hiding elements hiding elements hiding element…

    2025年12月24日
    400
  • 居中 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看垂直中心 – codesandbox 和水平中心的视觉效果。 通过 css 居中 垂直居中 centering centering centering centering centering centering立即…

    2025年12月24日 好文分享
    300
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 如何在移动端实现子 div 在父 div 内任意滑动查看?

    如何在移动端中实现让子 div 在父 div 内任意滑动查看 在移动端开发中,有时我们需要让子 div 在父 div 内任意滑动查看。然而,使用滚动条无法实现负值移动,因此需要采用其他方法。 解决方案: 使用绝对布局(absolute)或相对布局(relative):将子 div 设置为绝对或相对定…

    2025年12月24日
    000
  • 移动端嵌套 DIV 中子 DIV 如何水平滑动?

    移动端嵌套 DIV 中子 DIV 滑动 在移动端开发中,遇到这样的问题:当子 DIV 的高度小于父 DIV 时,无法在父 DIV 中水平滚动子 DIV。 无限画布 要实现子 DIV 在父 DIV 中任意滑动,需要创建一个无限画布。使用滚动无法达到负值,因此需要使用其他方法。 相对定位 一种方法是将子…

    2025年12月24日
    000
  • 移动端项目中,如何消除rem字体大小计算带来的CSS扭曲?

    移动端项目中消除rem字体大小计算带来的css扭曲 在移动端项目中,使用rem计算根节点字体大小可以实现自适应布局。但是,此方法可能会导致页面打开时出现css扭曲,这是因为页面内容在根节点字体大小赋值后重新渲染造成的。 解决方案: 要避免这种情况,将计算根节点字体大小的js脚本移动到页面的最前面,即…

    2025年12月24日
    000
  • Nuxt 移动端项目中 rem 计算导致 CSS 变形,如何解决?

    Nuxt 移动端项目中解决 rem 计算导致 CSS 变形 在 Nuxt 移动端项目中使用 rem 计算根节点字体大小时,可能会遇到一个问题:页面内容在字体大小发生变化时会重绘,导致 CSS 变形。 解决方案: 可将计算根节点字体大小的 JS 代码块置于页面最前端的 标签内,确保在其他资源加载之前执…

    2025年12月24日
    200
  • Nuxt 移动端项目使用 rem 计算字体大小导致页面变形,如何解决?

    rem 计算导致移动端页面变形的解决方法 在 nuxt 移动端项目中使用 rem 计算根节点字体大小时,页面会发生内容重绘,导致页面打开时出现样式变形。如何避免这种现象? 解决方案: 移动根节点字体大小计算代码到页面顶部,即 head 中。 原理: flexível.js 也遇到了类似问题,它的解决…

    2025年12月24日
    000
  • 形状 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看 codesandbox 的视觉效果。 通过css绘制各种形状 如何在 css 中绘制正方形、梯形、三角形、异形三角形、扇形、圆形、半圆、固定宽高比、0.5px 线? shapes 0.5px line .square { w…

    2025年12月24日
    000
  • 有哪些美观的开源数字大屏驾驶舱框架?

    开源数字大屏驾驶舱框架推荐 问题:有哪些美观的开源数字大屏驾驶舱框架? 答案: 资源包 [弗若恩智能大屏驾驶舱开发资源包](https://www.fanruan.com/resource/152) 软件 [弗若恩报表 – 数字大屏可视化组件](https://www.fanruan.c…

    2025年12月24日
    000
  • 网站底部如何实现飘彩带效果?

    网站底部飘彩带效果的 js 库实现 许多网站都会在特殊节日或活动中添加一些趣味性的视觉效果,例如点击按钮后散发的五彩缤纷的彩带。对于一个特定的网站来说,其飘彩带效果的实现方式可能有以下几个方面: 以 https://dub.sh/ 网站为例,它底部按钮点击后的彩带效果是由 javascript 库实…

    2025年12月24日
    000
  • 您不需要 CSS 预处理器

    原生 css 在最近几个月/几年里取得了长足的进步。在这篇文章中,我将回顾人们使用 sass、less 和 stylus 等 css 预处理器的主要原因,并向您展示如何使用原生 css 完成这些相同的事情。 分隔文件 分离文件是人们使用预处理器的主要原因之一。尽管您已经能够将另一个文件导入到 css…

    2025年12月24日
    000
  • 网站彩带效果背后是哪个JS库?

    网站彩带效果背后是哪个js库? 当你访问某些网站时,点击按钮后,屏幕上会飘出五颜六色的彩带,营造出庆祝的氛围。这些效果是通过使用javascript库实现的。 问题: 哪个javascript库能够实现网站上点击按钮散发彩带的效果? 答案: 根据给定网站的源代码分析: 可以发现,该网站使用了以下js…

    好文分享 2025年12月24日
    100
  • 产品预览卡项目

    这个项目最初是来自 Frontend Mentor 的挑战,旨在使用 HTML 和 CSS 创建响应式产品预览卡。最初的任务是设计一张具有视觉吸引力和功能性的产品卡,能够无缝适应各种屏幕尺寸。这涉及使用 CSS 媒体查询来确保布局在不同设备上保持一致且用户友好。产品卡包含产品图像、标签、标题、描述和…

    2025年12月24日
    100
  • React 嵌套组件中,CSS 样式会互相影响吗?

    react 嵌套组件 css 穿透影响 在 react 中,嵌套组件的 css 样式是否会相互影响,取决于采用的 css 解决方案。 传统 css 如果使用传统的 css,在嵌套组件中定义的样式可能会穿透影响到父组件。例如,在给出的代码中: 立即学习“前端免费学习笔记(深入)”; component…

    2025年12月24日
    000
  • 如何利用 echarts-gl 绘制带发光的 3D 图表?

    如何绘制带发光的 3d 图表,类似于 echarts 中的示例? 为了实现类似的 3d 图表效果,需要引入 echarts-gl 库:https://github.com/ecomfe/echarts-gl。 echarts-gl 专用于在 webgl 环境中渲染 3d 图形。它提供了各种 3d 图…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信