大连码上未来IT培训

ES6模块化是什么?怎样导入和执行模块中的代码?

作者:码上未来CodingFuture 来源:码上未来CodingFuture
发布日期:2024年06月17日

在 ES6 模块化规范诞生之前,JavaScript 社区已...

在 ES6 模块化规范诞生之前,JavaScript 社区已经尝试并提出了 AMD、CMD、CommonJS 等模块化规范。但是,这些由社区提出的模块化标准,还是存在一定的差异性与局限性、并不是浏览器与服务器通用的模块化标准,例如:①AMD 和 CMD 适用于浏览器端的 Javascript 模块化②CommonJS 适用于服务器端的 Javascript 模块化太多的模块化规范给开发者增加了学习的难度与开发的成本。因此,大一统的 ES6 模块化规范诞生了!ES6 模块化规范是浏览器端与服务器端通用的模块化开发规范。它的出现极大的降低了前端开发者的模块化学习成本,开发者不需再额外学习 AMD、CMD 或 CommonJS 等模块化规范。ES6 模块化规范中每个 js 文件都是一个独立的模块,导入其它模块成员需要使用 import 关键字,向外共享模块成员使用 export 关键字。在node.js中我们可以体验ES6模块化:node.js 中默认仅支持 CommonJS 模块化规范,若想基于node.js 体验与学习 ES6 的模块化语法,可以按照如下两个步骤进行配置:① 确保安装了 v14.15.1 或更高版本的 node.js② 在 package.json 的根节点中添加 "type": "module" 节点默认导出的语法:export default 默认导出的成员,导出语法如以下文件所示:letn1=10//定义模块私有成员n1let n2 = 20 //定义模块私有成员n2 (外界访问不到n2, 因为它没有被共享出去)function show() {} //定义模块私有方法show[]export default { //使用export default 默认导出语法,向外共享n1和show 两个成员n1,show}默认导入的语法:import 接收名称 from '模块标识符',导入语法如以下文件所示://从01_ _m1.js 模块中导入export default 向外共享的成员//并使用m1成员进行接收import m1 from ' ./01_ m1.js'//打印输出的结果为://{n1:10,show: [Function: show] }console. log(m1 )注意事项:在默认导出中每个模块,只允许使用的一次 export default,否则会报错!示例代码如下以下文件:letn1=10//定义模块私有成员n1let n2 = 20 //定义模块私有成员n2 (外界访问不到n2,因为它没有被共享出去)function show() {} /1定义模块私有方法showexport default { //使用export default 默认导出语法,向外共享n1和show 两个成员n1,show}// SyntaxError: Identifier ' .default' has already been declared export default {n2}默认导入时的接收名称可以任意名称,只要是合法的成员名称即可,示例代码如下:// m1是合法的名称// import m1 from './01_ m1.js '// 123m 不是合法的名称,因为成员名称不能以数字开头import 123m from ' ./01 m1.js '按需导出的语法:export 按需导出的成员,导出语法如以下文件所示://当前模块为03_ m2.js //向外按需导出变量s1exportlets1='aaa //向外按需导出变量s2 export let s2 = 'CCC ' //向外按需导出方法say export function say() {}按需导入的语法:import { s1 } from '模块标识符',导入语法如以下文件所示://导入模块成员import { s1, s2, say } from ' ./03_ m2.js 'console.log(s1) //打印输出aaaconsole. log(s2) // 打印输出CCCconsole.log(say) //打印输出[Function: say]按需导出与按需导入的注意事项:①每个模块中可以使用多次按需导出②按需导入的成员名称必须和按需导出的名称保持一致③按需导入时,可以使用 as 关键字进行重命名④按需导入可以和默认导入一起使用如果只想单纯地执行某个模块中的代码,并不需要得到模块中向外共享的成员。此时,可以直接导入并执行模块代码,示例代码如下://当前文件模块为05_ m3.js//在当前模块中执行一个 for 循环操作for(let i=0; i<3; i++) { console.log(i)}//-----------------分割线-----------------//直接导入并执行模块代码,不需要得到模块向外共享的成员import ' ./05_ m3.js'码上未来IT实训课程优势01课程内容牛  ●Java、Web、Python、互联网全栈开发、AIGC视觉设计&全媒体运营、短视频运     营、视频剪辑、平面设计、电商设计及运营等开发课程,每年迭代课程内容●真实企业资源,学习更深入02专家技术牛  ●技术大咖根据课程体系分重点、分阶段授课●5年以上企业一线开发经验项目经理、技术大牛实战授课03实训案例牛 ●真实的企业一线产品需求案例●全部来自一线的项目经理, 带来真实需求一线项目04学习模式牛 ●6个月全日制实训学习,真实的项目经验●讲练结合,掌握更熟练,全程技术老师跟踪辅导05就业服务牛 ●毕业即就业,学员就业●保薪资就业协议 入学即签订●4-5轮模拟面试+职业素养课程,全程跟踪,为就业保驾护航●毕业学生享受技术大咖终身支持指导课程适用人群●大学应往届生学习进修、在职提升、转行充电人群;●会基本的电脑操作,打字、有无编程基础均可;●对互联网编程感兴趣,想往网站开发、软件工程、大数据方向发展的人群;●低学历人群经过入学测试后方可选修。更多精彩推荐◡̈ 打破时间束缚,掌握一技之长才是硬道理◡̈  提升学历,为职业成功铺路◡̈   提高你的职场竞争力:IT培训是关键!◡̈ 你有面试困难症?手把手教你解决
加微信咨询
夏老师 @码上未来IT培训
微信号:155******12

资深职业咨询规划师

微信咨询
相关资讯
jquery事件绑定方法有哪些? 关于Web的相关的面试题(四十) 收获的季节,IT技能提升的良机! 关于Web的相关的面试题(三十九) jquery基本选择和层次选择器详细介绍
相关课程