Learn these core JavaScript concepts in just a few minutes(只需几分钟即可学习这些核心JavaScript概念)

原文地址:https://medium.freecodecamp.org/learn-these-core-javascript-concepts-in-just-a-few-minutes-f7a16f42c1b0

我们将关注的JS概念:

  • Scope
  • IIFE
  • MVC
  • Async/await
  • Closure
  • Callback

1.scope(域)

域只是一个带边界的框。 JS中有两种类型的边界:局部和全局,也称为内部和外部。

本地意味着您可以访问边界内(框内)的所有内容,而全局是边界之外的所有内容(框外)。

当我们谈论类,函数和方法时,这些术语会被大量使用。它提供了确定当前上下文的可访问(可见)内容的功能。

ES5

ES6

如上例所示,函数showName()可以访问在其边界(本地)内部以及外部(全局)定义的所有内容。请记住,全局范围不能访问在本地范围内定义的变量,因为它是从外部世界包含的,除非您将其返回。

2. IIFE(立即执行函数)

IIFE(立即调用函数表达式),因为名称状态意味着函数在创建时“立即调用”。在ES6 ++提出支持面向对象编程范例(OOP)的类/方法之前,常见的方法是将IIFE模仿为类名,并将函数作为包含在返回类型中的方法调用。

优点:

  • 立即执行代码
  • 避免全球范围受到污染
  • 支持异步结构
  • 提高可读性

ES5

ES6

在上面的例子中,我们在returntype(changeColorToRed()和changeColorToBlack())中包含了两个函数。这允许我们访问多个函数,并调用我们想要的方法。

简而言之,我们首先调用汽车(函数表达式)以访问内部的内容。然后我们可以使用。用于调用返回类型中定义的函数的表示法。这种方法类似于我们在调用方法名之前首先调用类名的类/方法的结构。这样您就可以编写干净,可维护且可重用的代码。

3. MVC

模型 - 视图 - 控制器是一种设计框架(*不是编程语言),它允许我们将行为分离为实际的现实世界结构。今天,几乎85%的基于Web的应用程序都以这种或那种方式具有这种基础模式。还有其他类型的设计框架,但这是迄今为止最基本和易于理解的模式。

ES5

ES6

如上例所示,我们通常会根据最佳实践将视图,模型和控制器划分为单独的文件夹/文件,但为了说明这个概念,我们将它们全部放在一个文件中。设计框架的目标是简化开发过程并支持可持续的协作环境。

4. Async/await

停下来等待问题得到解决。它提供了一种以更同步的方式维护异步处理的方法。例如,在允许用户进入系统之前,您需要检查用户的密码是否正确(与服务器中存在的密码相比)。或者您可能已执行REST API请求,并且希望在将数据推送到视图之前完全加载数据。

优点:

  • 同步功能
  • 控制行为
  • 减少“回调地狱”

ES5

ES6

为了使用await,我们必须将它包装在异步函数中,以通知JS我们正在使用promises。如示例所示,我们(a)等待两件事:响应和用户。在我们将响应转换为JSON格式之前,我们需要确保获取响应,否则我们最终可能会转换尚未响应的响应,这很可能会导致错误。

5. Closure(闭包)

闭包只是另一个函数内部的函数。当您想要将诸如传递变量,方法或数组之类的行为从外部函数扩展到内部函数时,可以使用它。我们也可以从内部函数访问外部函数中定义的上下文,但不能反过来(请记住我们上面讨论的范围原则)。

特点:

  • 扩展行为
  • 在处理事件时很有用

ES5

ES6

函数showName()是一个Closure,因为它扩展了函数showInfo()的行为,并且还可以访问变量carType。

6. Callback(回调)

回调是在执行另一个函数后执行的函数。它也被称为回拨。在JavaScript世界中,等待另一个函数执行或返回值(数组或对象)的函数称为回调。回调是一种使异步操作更加同步(顺序)的方法。

特点:

  • 等待事件执行
  • 提供同步功能
  • 链函数的实用方法(如果A完成,则执行B,等等)
  • 提供代码结构和控制

请注意,您可能听说过回调地狱。它基本上意味着你有一个递归的回调结构(回调中回调中的回调等等)。这不切实际。

ES5

ES6

请注意,它在执行操作(启动引擎)之前等待事件发生(按钮单击)。简而言之,我们将fireUpEngines()函数作为参数(回调)传递给pressButton()函数。当用户按下按钮时,它会启动引擎。

本文将一些最流行的JS概念仅通过示例进行了解释。我希望这些概念能帮助你更多地了解JS以及它是如何工作的。

—— 完 ——

最新文章

  1. lua解析赋值类型代码的过程
  2. 使用MyEclipse 9.0 创建 struts2 的HelloWorld 工程
  3. Codeforces Round #373 (Div. 2)
  4. NOSDK--一键打包的实现(四)
  5. tomcat架构分析 (Session管理)
  6. iOS----------使用 Xcode6或Xcode7配置.pch文件
  7. 当一个activity中按钮过多时怎么办?
  8. pageX和pageY
  9. activiti源码分析(一)设计模式
  10. PHP工程师面临成长瓶颈
  11. nagios安装全过程
  12. HTML5不允许写结束标记的元素
  13. webpack.config.js配置遇到Error: Cannot find module '@babel/core'&&Cannot find module '@babel/plugin-transform-react-jsx' 问题
  14. Linux NGINX部署
  15. 调整分区大小 转载--------------http://blog.csdn.net/perfectzq/article/details/73606119
  16. PostgreSQL+PostGIS安装以及使用
  17. keil小技能随用随定义
  18. C#获取文件版本、文件大小等信息
  19. zabbix 触发器描述列表count
  20. Unix环境高级编程(二十)伪终端

热门文章

  1. Java线程池的选择
  2. HBase 使用外部的 zookeeper
  3. 【Three.js】模型抗锯齿处理
  4. LINQ入门教程之各种标准查询操作符(二)
  5. (转)WordPress常用模板函数 修改或自制WordPress主题必备
  6. net与树莓派的情缘(二)
  7. solr实时更新mysql数据的方法
  8. rpm: error while loading shared libraries: libgcc_s.so.1: cannot open shared object file: No such file or directory解决办法
  9. JavaScript数据结构-13.散列碰撞(开链法)
  10. JavaScript数据结构-4.栈操作