广告
返回顶部
首页 > 资讯 > 精选 >如何解析es6模块
  • 129
分享到

如何解析es6模块

2023-06-28 02:06:01 129人浏览 八月长安
摘要

这篇文章主要为大家分析了如何解析es6模块的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“如何解析es6模块”的知识吧。ES6就是ECMAScript的第6个

这篇文章主要为大家分析了如何解析es6模块的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“如何解析es6模块”的知识吧。

ES6就是ECMAScript的第6个版本,ECMAScript 6.0(以下简称 ES6)是 javascript 语言的下一代标准,已经在 2015 年 6 月正式发布了。它的目标,是使得 JavaScript 语言可以用来编写复杂的大型应用程序,成为企业级开发语言,下面为大家详细讲解一下es6模块。

概述

在 ES6 前, 实现模块化使用的是 Requirejs 或者 seaJS(分别是基于 AMD 规范的模块化库, 和基于 CMD 规范的模块化库)。

ES6 引入了模块化,其设计思想是在编译时就能确定模块的依赖关系,以及输入和输出的变量。

ES6 的模块化分为导出(export) @与导入(import)两个模块。

特点

ES6 的模块自动开启严格模式,不管你有没有在模块头部加上 use strict;。

模块中可以导入和导出各种类型的变量,如函数,对象,字符串,数字,布尔值,类等。

每个模块都有自己的上下文,每一个模块内声明的变量都是局部变量,不会污染全局作用域。

每一个模块只加载一次(是单例的), 若再去加载同目录下同文件,直接从内存中读取。

export 与 import

基本用法

模块导入导出各种类型的变量,如字符串,数值,函数,类。

  1. 导出的函数声明与类声明必须要有名称(export default 命令另外考虑)。
  2. 不仅能导出声明还能导出引用(例如函数)。
  3. export 命令可以出现在模块的任何位置,但必需处于模块顶层。
  4. import 命令会提升到整个模块的头部,首先执行。
let myName = "Tom";let myAge = 20;let myfn = function(){   return "My name is" + myName + "! I'm '" + myAge + "years old."}let myClass =  class myClass {   static a = "yeah!";}export { myName, myAge, myfn, myClass }import { myName, myAge, myfn, myClass } from "./test.js";console.log(myfn());// My name is Tom! I'm 20 years old.console.log(myAge);// 20console.log(myName);// Tomconsole.log(myClass.a );// yeah!

建议使用大括号指定所要输出的一组变量写在文档尾部,明确导出的接口。

函数与类都需要有对应的名称,导出文档尾部也避免了无对应名称。

as 的用法

export 命令导出的接口名称,须和模块内部的变量有一一对应关系。

导入的变量名,须和导出的接口名称相同,即顺序可以不一致。

let myName = "Tom";export { myName as exportName }import { exportName } from "./test.js";console.log(exportName);// Tom使用 as 重新定义导出的接口名称,隐藏模块内部的变量let myName = "Tom";export { myName }let myName = "Jerry";export { myName }import { myName as name1 } from "./test1.js";import { myName as name2 } from "./test2.js";console.log(name1);// Tomconsole.log(name2);// Jerry

不同模块导出接口名称命名重复, 使用 as 重新定义变量名。

import 命令的特点

只读属性:不允许在加载模块的脚本里面,改写接口的引用指向,即可以改写 import 变量类型为对象的属性值,不能改写 import 变量类型为基本类型的值。

import {a} from "./xxx.js"a = {}; // errorimport {a} from "./xxx.js"a.foo = "hello"; // a = { foo : 'hello' }

单例模式:多次重复执行同一句 import 语句,那么只会执行一次,而不会执行多次。import 同一模块,声明不同接口引用,会声明对应变量,但只执行一次 import 。

import { a } "./xxx.js";import { a } "./xxx.js";// 相当于 import { a } "./xxx.js";import { a } from "./xxx.js";import { b } from "./xxx.js";// 相当于 import { a, b } from "./xxx.js";

静态执行特性:import 是静态执行,所以不能使用表达式和变量。

import { "f" + "oo" } from "methods";// errorlet module = "methods";import { foo } from module;// errorif (true) { import { foo } from "method1";} else { import { foo } from "method2";}// error

export default 命令

  1. 在一个文件或模块中,export、import 可以有多个,export default 仅有一个。
  2. export default 中的 default 是对应的导出接口变量。
  3. 通过 export 方式导出,在导入时要加{ },export default 则不需要。
  4. export default 向外暴露的成员,可以使用任意变量来接收。
var a = "My name is Tom!";export default a; // 仅有一个export default var c = "error";// error,default 已经是对应的导出变量,不能跟着变量声明语句import b from "./xxx.js"; // 不需要加{}, 使用任意变量接收

复合使用

注:import() 是提案,这边暂时不延伸讲解。

export 与 import 可以在同一模块使用,使用特点:

  1. 可以将导出接口改名,包括 default。
  2. 复合使用 export 与 import ,也可以导出全部,当前模块导出的接口会覆盖继承导出的。
export { foo, bar } from "methods";// 约等于下面两段语句,不过上面导入导出方式该模块没有导入 foo 与 barimport { foo, bar } from "methods";export { foo, bar };// 普通改名export { foo as bar } from "methods";// 将 foo 转导成 defaultexport { foo as default } from "methods";// 将 default 转导成 fooexport { default as foo } from "methods";export * from "methods";

关于“如何解析es6模块”就介绍到这了,更多相关内容可以搜索编程网以前的文章,希望能够帮助大家答疑解惑,请多多支持编程网网站!

--结束END--

本文标题: 如何解析es6模块

本文链接: https://www.lsjlt.com/news/315696.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 如何解析es6模块
    这篇文章主要为大家分析了如何解析es6模块的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“如何解析es6模块”的知识吧。ES6就是ECMAScript的第6个...
    99+
    2023-06-28
  • 详解Node.js如何处理ES6模块
    目录一、两种模块的差异二、Node.js 的区分三、CommonJS 模块加载 ES6 模块四、ES6 模块加载 CommonJS 模块五、同时支持两种格式的模块一、两种模块的差异 ...
    99+
    2022-11-12
  • JavaScript ES6 Module模块详解
    目录0.什么是Module1.Module 的加载1.1 方式一1.2 方式二2.导出和导入2.1 一个模块的导出可以被其它模块导入,并访问。2.2 没有导出,也可以将其导入2.3 ...
    99+
    2022-11-12
  • es6模块化如何使用
    本篇内容介绍了“es6模块化如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!天下苦 CommonJs 久矣Es Module 的独特之...
    99+
    2023-07-05
  • Webpack4入口、输入和ES6模块分析
    这篇文章主要讲解了“Webpack4入口、输入和ES6模块分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Webpack4入口、输入和ES6模块分析”吧!...
    99+
    2022-10-19
  • 一文详解es6中的模块化
    Es Module 的解析流程在开始之前,我们先大概了解一下整个流程大概是怎么样的,先有一个大概的了解:阶段一:构建(Construction),根据地址查找 js 文件,通过网络下载,并且解析模块文件为 Module Record;阶段二...
    99+
    2022-11-22
    ES6 前端 JavaScript 面试
  • ES6新特性之解构、参数、模块和记号的示例分析
    这篇文章主要介绍了ES6新特性之解构、参数、模块和记号的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体如下:一、解构解构提供了一...
    99+
    2022-10-19
  • Python模块域名dnspython解析
    目录dnspython源码安装python模块域名解析方法讲解总结dnspython是python实现的一个DNS工具包,它支持记录类型、查询、传输并动态更新ZONE信息等等。据说d...
    99+
    2022-11-11
  • 如何分析Python OS 模块
    这篇文章给大家介绍如何分析Python OS 模块,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。python os模块Python的标准库中的os模块包含普遍的操作系统功能。如果你希望你的程序能够与平台无关的话,这个模...
    99+
    2023-06-04
  • nodejs模块学习之connect解析
    nodejs 发展很快,从 npm 上面的包托管数量就可以看出来。不过从另一方面来看,也是反映了 nodejs 的基础不稳固,需要开发者创造大量的轮子来解决现实的问题。 知其然,并知其所以然这是程序员的天性...
    99+
    2022-06-04
    模块 nodejs connect
  • Python中functools模块函数解析
    Python自带的 functools 模块提供了一些常用的高阶函数,也就是用于处理其它函数的特殊函数。换言之,就是能使用该模块对可调用对象进行处理。 functools模块函数概览 functoo...
    99+
    2022-06-04
    函数 模块 Python
  • python xlwt模块的使用解析
    目录一、基础类介绍1、工作簿类Workbook简介:2、工作表类WorkSheet简介3、创建一个不带样式的基础Excel表二、xlwt高级应用1、字体类Font简介1.1创建一个改...
    99+
    2022-11-12
  • python 命令行 解析模块 optp
      Python: 使用 optparse 处理命令行参数 python optparse命令解析模块:https://www.cnblogs.com/pping/p/3989098.html python optparse模块的简单用法...
    99+
    2023-01-31
    命令行 模块 python
  • webpack模块化的原理解析
    目录commonjs编译结果require 函数ES Module编译结果v5 的变化两种模块化交互编译结果总结commonjs 在webpack中既可以书写commonjs模块也可...
    99+
    2023-02-28
    webpack模块化 webpack模块化原理
  • 深入解析Python中的urllib2模块
    Python 标准库中有很多实用的工具类,但是在具体使用时,标准库文档上对使用细节描述的并不清楚,比如 urllib2 这个 HTTP 客户端库。这里总结了一些 urllib2 的使用细节。 Prox...
    99+
    2022-06-04
    模块 Python
  • Django drf请求模块源码解析
    DRF 框架,全称为 Django Rest Framework,是 Django 内置模块的扩展,用于创建标准化 RESTful API;它利用 ORM 映射数据库,并自定义序列化...
    99+
    2022-11-12
  • Node模块化开发实例解析
    目录一、介绍1. 什么是模块化开发2. Node.js中的模块化3. 模块化开发的优点二、CommonJS规范1. CommonJS规范介绍2. Node.js中的模块加载机制3. ...
    99+
    2023-03-13
    Node模块化开发 Node 模块化
  • 如何理解JavaScript模块化
    目录1. 浏览器支持2. export 导出模块3. import 导入模块4. 创建模块对象5. export import 中转站6. 动态加载模块1. 浏览器支持 使用Java...
    99+
    2022-11-12
  • 如何理解Node.js模块化
    本篇内容主要讲解“如何理解Node.js模块化”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解Node.js模块化”吧!正文在Node.js中,内置了两个...
    99+
    2022-10-19
  • JavaScript 模块化如何理解
    这期内容当中小编将会给大家带来有关JavaScript 模块化如何理解,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。前言:1.概念将一个复杂的程序依据一定的规则(规范)封装成几个块(文件), 并...
    99+
    2023-06-22
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作