ES6 为什么要出Module模块及用法,vue前端开发

本文介绍了ES6引入模块化的背景和好处,包括不再依赖AMD或CMD规范,以及浏览器和服务器对模块的支持。文章详细阐述了export和import命令的用法,以及模块的定义和导出方式,强调了模块的严格模式和单例特性。最后,作者分享了个人前端开发经验和学习资源,鼓励读者克服技术学习的挑战。
摘要由CSDN通过智能技术生成

目录

  • Module模块

    • 概念
  • export 与 import

    • 模块的定义
  • 模块导出

  • 模块的引用

  • 默认模块

  • 浏览器加载模块

概念


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

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

好处:

  1. 不再需要UMD模块格式了,将来服务器和浏览器都会支持 ES6 模块格式。目前,通过各种工具库,其实已经做到了这一点

  2. 将来浏览器的新 API 就能用模块格式提供,不再必须做成全局变量或者navigator对象的属性

  3. 不再需要对象作为命名空间(比如Math对象),未来这些功能可以通过模块提供

特点:

  1. ES6 的模块自动开启严格模式

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

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

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

回到顶部 目录

export 与 import


模块功能主要由两个命令构成:

  • 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前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

你要问前端开发难不难,我就得说计算机领域里常说的一句话,这句话就是『难的不会,会的不难』,对于不熟悉某领域技术的人来说,因为不了解所以产生神秘感,神秘感就会让人感觉很难,也就是『难的不会』;当学会这项技术之后,知道什么什么技术能做到什么做不到,只是做起来花多少时间的问题而已,没啥难的,所以就是『会的不难』。

我特地针对初学者整理一套前端学习资料,免费分享给大家,戳这里即可免费领取

前端路线图

不熟悉某领域技术的人来说,因为不了解所以产生神秘感,神秘感就会让人感觉很难,也就是『难的不会』;当学会这项技术之后,知道什么什么技术能做到什么做不到,只是做起来花多少时间的问题而已,没啥难的,所以就是『会的不难』。

我特地针对初学者整理一套前端学习资料,免费分享给大家,戳这里即可免费领取

[外链图片转存中…(img-BaIq4SU0-1712098436154)]

vue.js的36个技巧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值