JavaScript模块化

一小时速通JavaScript模块化,涵盖CommonJS与ES6模块化_哔哩哔哩_bilibili本视频讲解的是JavaScript模块化技术,无论前端还是后端,模块化技术都是开发的必备技能,本视频着重讲解了当下流行的两大模块化技术:CommonJS与ES6模块化,讲解细致入微,并演示了一些常见的"坑",同时也对其他模块化技术做了简单的讲解,一起学起来吧!, 视频播放量 12726、弹幕量 62、点赞数 582、投硬币枚数 324、收藏人数 1227、转发人数 57, 视频作者 尚硅谷, 作者简介 就业规划、简历模板、毕业设计,加小谷姐姐Q:3276742687,相关视频:2023黑马前端JavaScript进阶ES6进阶到JS高级,构造函数&ES6+函数_js深入面向对象,2024前端JavaScript入门到精通全套视频教程,javascript核心进阶ES6语法、API、js高级等基础知识和实战教程全集,你还在手写CSS效果?,黑马程序员前端JavaScript入门到精通全套视频教程,javascript核心进阶ES6语法、API、js高级等基础知识和实战教程,JavaScript前端课程-dom-bom-js-es6新语法-jQuery-数据可视化echarts黑马pink老师前端入门基础视频教程(500多集)持续,黑马程序员前端React18入门到实战视频教程,从react+hooks核心基础到企业级项目开发实战(B站评论、极客园项目等)及大厂面试全通关,Vue3 + vite + Ts + pinia + 实战 + 源码 + electron,尚硅谷Nginx教程(亿级流量nginx架构设计),跪了!GitHub标星122K!!百星仓库---程序界的封神之作 project based learning,自学编程学习指南!,3小时前端入门教程(HTML+CSS+JS)https://www.bilibili.com/video/BV13W42197jR/?spm_id_from=333.1007.top_right_bar_window_history.content.click

模块化概述:

(1)什么是模块化?

  • 将程序文件依据一定规则拆分成多个文件,这种编码方式就是 模块化 的编码方式。
  • 拆分出来每个文件就是一个模块 ,模块中的数据都是私有的 ,模块之间互相隔离
  • 同时也能通过一些手段,可以把模块内的指定数据**"交出去"**,供其他模块使用。

(2)为什么需要模块化?

随着应用的复杂度越来越高,其代码量文件数量都会急剧增加,会逐渐引发以下问题:

  1. 全局污染问题
  2. 依赖混乱问题
  3. 数据安全问题

同名函数后引入会覆盖掉前一个函数的内容


(3)有哪些模块化?

2009 年,随着 Node.js 的出现,JavaScript 在服务器端的应用逐渐增多,为了让Node.js 的代码更好维护,就必须要制定一种 Node.js 环境下的模块化规范,来自 Mozila 的工程师Kevin Dangoor 提出了 CommonJS 规范(CommonJs 初期的名字叫 ServerJs),随后 Node.js 社区采纳了这一规范。

随着时间的推移,针对 JavaScript 的不同运行环境,相继出现了多种模块化规范,按时间排序,分别为:

  1. CommonJS------服务端应用广泛
  2. AMD
  3. CMD
  4. ES6 模块化------浏览器端应用广泛

(4)导入与导出思想

模块化的核心思想就是: 模块之间是隔离 的,通过导入导出进行数据和功能的共享

  • **导出(暴露):**模块公开其内部的一部分(如变量、函数等),使这些内容可以被其他模块使用。
  • **导入(引入):**模块引用和使用其他模块导出的内容,以重用代码和功能

CommonJS 规范

(1)导出数据:

在 CommonJS 标准中,导出数据有两种方式:

  1. module.exports =value
  2. exports.name =value

注意:

1.每个模块内部的: this、exports、modules.exports 在初始时,都指向同一个空对象,该

空对象就是当前模块导出的数据,如下图:

2.无论如何修改导出对象,最终导出的都是 module.exports的值

  1. exports 是对 module.exports 的初始引用,仅为了方便给导出象添加属性,所以不能使用

exports = value 的形式导出数据,但是可以使用 module.exports=xxxx 导出数据。

(2)导入数据:

在 CJS 模块化标准中,使用内置的 require 函数进行导入数据

解构再重命名可以解决导入重名的问题

(3)扩展:

一个JS模块在执行时,是被包裹在一个内置函数中执行的,所以每个模块都有自己的作用域,我们可以通过如下方式验证这一说法:

javascript 复制代码
console.log(arguments)
console.log(arguments.callee.toString())

内置函数的大致形式如下:


ES6 模块化

ES6 模块化规范是一个官方标准的规范,它是在语言标准的层面上实现了模块化功能,是目前最流行的模块化规范,且浏览器与服务端均支持该规范。

(1)导出数据:

ES6 模块化提供3种导出方式: ①分别导出、②统一导出、③默认导出

①分别导出:

②默认导出:

③默认导出:

备注:上述多种导出方式,可以同时使用

(2)导入数据:

对于 ES6 模块化来说,使用何种导入方式,要根据导出方式决定。

①「命名导入」(对应导出方式:分别导出、统一导出)

②「默认导入」(对应导出方式:默认导出)

「【命名导入】 与 【默认导入】可以混合使用」

③「动态导入」(通用)

import 可以不接收任何数据


数据引用问题

(1)如下代码的输出结果是什么?

结果1 1 (increment调用加的是increment函数里面的sum,但是一开始调用的是外层的sum,两个不是一个sum)

(2)使用 CommonJS 规范,编写如下代码,输出结果是什么?

同样是1 1(解构赋值)

(3)使用ES6 模块化规范编写如下代码,输出结果是什么?

let sum 的话打印出来是 1 3

最好声明为常量,因为import导入时一般为常量(只读),data.js的数据假设声明为变量,会指向同一个内存空间,这样子就能够修改sum的数据了。因此最好是将data.js的数据声明为常量。


AMD 模块化规范(了解)

①准备文件结构:

文件说明:

1.js 文件夹中存放业务逻辑代码, main.js 用于汇总各模块。

2.libs 中存放的是第三方库,例如必须要用的 require.js

②在index.html中配置main.js 与 require.js

③在 main.js 中编写模块配置对象,注册所有块。

AMD 规范使用 define 函数来定义模块和导出数据

(1)导出数据:

(2)导入数据:


CMD 模块化规范(了解)

写法类似 CJS 和 AMD 进行结合

(1)导出数据:

CMD 中同样使用 define 函数定义模块并导出数据

(2)导入数据:

CMD 规范中使用收到的 require参数进行模块导入

相关推荐
码力全開5 分钟前
C 语言奇幻之旅 - 第06篇:C 语言控制流语句
c语言·开发语言·数据库·windows·visualstudio·vim
黑客老陈14 分钟前
JAVA XXE 学习总结
java·服务器·开发语言·python·学习·安全·web安全
喜欢踢足球的老罗17 分钟前
搭建一个本地轻量级且好用的学习TypeScript语言的环境
javascript·学习·typescript
豆豆(设计前端)19 分钟前
总结 Vue 请求接口的各种类型及传参方式
前端·javascript·vue.js
BestArsenaI19 分钟前
vue -关于浏览器localstorge数据定期清除的实现
javascript·vue.js·ecmascript
华东设计之美27 分钟前
java集合类有哪些?
java·开发语言
heath ceTide28 分钟前
Java项目中集成Github登录
java·开发语言·github
Smile_Gently30 分钟前
Element-plus、Element-ui之Tree 树形控件回显Bug问题。
javascript·vue.js·elementui
sin220132 分钟前
springmvc--对日期类型如何处理
java·开发语言