目录
在 ES6 前, 实现模块化使用的是 RequireJS 或者 seaJS(分别是基于 AMD 规范的模块化库, 和基于 CMD 规范的模块化库)。
ES6 引入了模块化,其设计思想是在编译时就能确定模块的依赖关系,以及输入和输出的变量。
好处:
-
不再需要UMD模块格式了,将来服务器和浏览器都会支持 ES6 模块格式。目前,通过各种工具库,其实已经做到了这一点
-
将来浏览器的新 API 就能用模块格式提供,不再必须做成全局变量或者navigator对象的属性
-
不再需要对象作为命名空间(比如Math对象),未来这些功能可以通过模块提供
特点:
-
ES6 的模块自动开启严格模式
-
模块中可以导入和导出各种类型的变量,如函数,对象,字符串,数字,布尔值,类等
-
每个模块都有自己的上下文,每一个模块内声明的变量都是局部变量,不会污染全局作用域
-
每一个模块只加载一次(是单例的), 若再去加载同目录下同文件,直接从内存中读取
回到顶部 目录
模块功能主要由两个命令构成:
-
export命令用于规定模块的对外接口
-
import命令用于输入其他模块提供的功能
模块的定义
模块是自动运行在严格模式下并且没有办法退出运行的JavaScript代码
模块可以是函数、数据、类,需要指定导出的模块名,才能被其他模块访问
// 数据模块
const obj = {name: ‘he’};
// 函数模块
const fn = (a, b) => a + b;
// 类模块
class My {}
模块导出
export命令必须出现在全局作用域,不然就报错
- 给需要导出的数据、函数、类添加一个export,就能导出模块
// 数据模块
export const obj = {name: ‘he’};
// 函数模块
export const fn = (a, b) => a + b;
// 类模块
export class My {}
- 可以通过as关键字给模块取别名
// 正常情况下模块名称为obj
export const obj = {name: ‘he’};
// 取别名后模块名称为module1
export {
obj as module1;
}
- 不同的写法
// 写法一
export var m = 1;
// 写法二
var m = 1;
export {m};
// 写法三
var n = 1;
export {n as m};
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)
最后
你要问前端开发难不难,我就得说计算机领域里常说的一句话,这句话就是『难的不会,会的不难』,对于不熟悉某领域技术的人来说,因为不了解所以产生神秘感,神秘感就会让人感觉很难,也就是『难的不会』;当学会这项技术之后,知道什么什么技术能做到什么做不到,只是做起来花多少时间的问题而已,没啥难的,所以就是『会的不难』。
我特地针对初学者整理一套前端学习资料,免费分享给大家,戳这里即可免费领取
不熟悉某领域技术的人来说,因为不了解所以产生神秘感,神秘感就会让人感觉很难,也就是『难的不会』;当学会这项技术之后,知道什么什么技术能做到什么做不到,只是做起来花多少时间的问题而已,没啥难的,所以就是『会的不难』。
我特地针对初学者整理一套前端学习资料,免费分享给大家,戳这里即可免费领取
[外链图片转存中…(img-BaIq4SU0-1712098436154)]