面试题57:commonjs与es6模块化有什么区别

122 篇文章 11 订阅
28 篇文章 2 订阅

commonjs与es6模块化有什么区别

区别:

1、CommonJS模块是运行时加载,而ES6模块是编译时输出接口;

2、CommonJS模块的require()是同步加载模块,而ES6模块的import命令是异步加载

3、CommonJS是对模块的浅拷贝,ES6是对模块的引入

CommonJS

  • 对于基本数据类型,属于复制。即会被模块缓存。同时,在另一个模块可以对该模块输出的变量重新赋值。

  • 对于复杂数据类型,属于浅拷贝。由于两个模块引用的对象指向同一个内存空间,因此对该模块的值做修改时会影响另一个模块

  • 当使用require命令加载某个模块时,就会运行整个模块的代码。

  • 当使用require命令加载同一个模块时,不会再执行该模块,而是取到缓存之中的值。也就是说,CommonJS模块无论加载多少次,都只会在第一次加载时运行一次,以后再加载,就返回第一次运行的结果,除非手动清除系统缓存。

  • 循环加载时,属于加载时执行。即脚本代码在require的时候,就会全部执行。一旦出现某个模块被"循环加载",就只输出已经执行的部分,还未执行的部分不会输出。

ES6模块

  • ES6模块中的值属于【动态只读引用】。

  • 对于只读来说,即不允许修改引入变量的值,import的变量是只读的,不论是基本数据类型还是复杂数据类型。当模块遇到import命令时,就会生成一个只读引用。等到脚本真正执行时,再根据这个只读引用,到被加载的那个模块里面去取值。

  • 对于动态来说,原始值发生变化,import加载的值也会发生变化。不论是基本数据类型还是复杂数据类型。

  • 循环加载时,ES6模块是动态引用。只要两个模块之间存在某个引用,代码就能够执行。

ES6模块与CommonJS模块的区别

1.CommonJS 模块是运行时加载,ES6 模块是编译时输出接口。

2.CommonJS 模块的require()是同步加载模块,ES6 模块的import命令是异步加载,有一个独立的模块依赖的解析阶段。

3.CommonJS是对模块的浅拷贝,ES6 Module是对模块的引入,即ES6 Module只存只读,不能改变其值,具体点就是指针指向不能变,类似const 。

4.import的接口是read-only(只读状态),不能修改其变量值。 即不能修改其变量的指针指向,但可以改变变量内部指针指向。可以对commonJS对重新赋值(改变指针指向),但是对ES6 Module赋值会编译报错。

ES6模块与CommonJS模块的共同点:

1.CommonJS和ES6 Module都可以对引⼊的对象进⾏赋值,即对对象内部属性的值进行改变。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我将根据您的要求回答您的问。现在让我们来看一些关于 CommonJSES6面试。 1. 什么是 CommonJSES6CommonJS 是一种模块规范,用于在服务器端和客户端 JavaScript 应用程序中定义模块。它定义了模块的导入和导出规则,使得模块可以在应用程序中重用。ES6(ECMAScript 2015)是 JavaScript 的一个版本,它引入了很多新的语言特性和功能,包括模块机制。 2. CommonJSES6 模块规范之间有什么区别CommonJS 是一种同步加载模块的规范,而 ES6 则是一种异步加载模块的规范。在 CommonJS 中,模块的导入和导出是通过 require() 和 module.exports 或 exports 来实现的,而在 ES6 中则是通过 import 和 export 语句来实现的。此外,ES6 还支持静态分析,这意味着编译器可以在编译时确定哪些模块将被导入和导出,以及它们的依赖关系。 3. ES6模块规范有哪些优点? ES6模块规范具有以下优点: - 易于维护和调试:ES6 模块的导入和导出语句更加清晰和简洁,使得代码更易于维护和调试。 - 静态分析:ES6 模块规范可以在编译时进行静态分析,这使得编译器可以优代码并检测潜在的错误。 - 更好的命名空间管理:ES6 模块规范通过使用命名空间来管理模块,从而避免了全局命名空间污染的问。 - 支持循环依赖:ES6 模块规范支持循环依赖,这意味着模块可以相互依赖而不会导致死循环。 4. CommonJS模块规范有哪些缺点? CommonJS模块规范有以下缺点: - 同步加载:由于 CommonJS 使用同步加载模块的方式,因此会导致应用程序的启动时间变慢。 - 无法进行静态分析:由于 CommonJS模块规范是动态的,因此编译器无法在编译时确定模块的依赖关系,这会导致一些潜在的错误。 - 无法进行优:由于 CommonJS 使用动态加载模块的方式,因此编译器无法对模块进行优,这会导致应用程序的性能问

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值