5 分钟比较理解 require() vs import()

简介: 我们都知道 require() 和 import() 都是用于导入模块的,但是它们差别大有不同,本篇 5 分钟带你进行比较理解~ 轻松易读,温故知新。

image.png

我们都知道 require()import() 都是用于导入模块的,但是它们差别大有不同,本篇 5 分钟带你进行比较理解~ 轻松易读,温故知新。


惟书有色,艳于西子;惟文有华,秀于百卉。—— 皮日休


  • require()


在 Node.js 中,require() 是一个内置函数,用于导入单独文件的外部模块;require() 可以读取 JavaScript 文件,执行它,并返回导出的对象。Require 不仅可以添加内置的核心 NodeJS 模块,还允许添加本地模块;


var myVar = require('http'); //to use built-in modules
var myVar2 = require('./myLocaModule'); //to use local modules


  • import()


import() 通常与 export() 成对出现,用于引入 ES 模块,属于 ES6 规范。它们只允许在 ES 模块中使用,无法使用它们导入具有其它文件类型(如 .json)的其它模块。可以用于导入以路径 URL 形式的资源或包名;如果 Script 脚本没有设置 type='module',则不能使用 import 语句;


var myVac = import("module-name");


  • require() vs import()


image.png


  1. require() 可以在任何地方被调用


通常,我们在文件开头调用 import() 或 require() 语句。但实际上,你可以在代码中的任何位置调用 require(),而 import() 语句只能在文件开头定义。在别处使用 import() 语句,会报错:要求移动到文件的开头。


// 报错
if (x > 2) {
  import a from "./a";
}
///repl: 'import' and 'export' may only appear at the top level (2:2)


import 命令会被 JS 引擎静态分析(编译阶段),先于其他模块执行,所以报错;

  1. require() 可以放在条件判断里面


代码如下:

//require
if(user.id == 1){
   const getBlogTitle = require(‘./blogDetails.js’);
}
//import
if(...) {   
  import ...; // Error, not allowed! 
}  
{   
  import ...; // Error, we can't put import in any block 
}


  1. ES 模块也可以动态调用


虽然上面说 import 写法不能放在条件判断里,但是 ES 模块也是支持动态调用的:

它的写法是 import (./xxx),而非 import x from './xxx'

此点非常重要,注意区分!

//dynamic import
let {hi, bye} = await import('./say.js');  
hi(); // Hello!
bye(); // Bye!
//OR
let say = await import('./say.js');     
say.hi(); // Hello!     
say.bye(); // Bye!


import() 加载模块成功以后,这个模块会作为一个对象,当作 then 方法的参数。因此,可以使用对象解构赋值的语法,获取输出接口。


import("./myModule.js").then(({ export1, export2 }) => {
  // ...·
});


  1. import() 是异步的;


在使用 require 命令加载模块时,就会运行整个模块的代码;

import 虽然写在文件顶部,但是脚本执行时,只有在碰到这个只读变量的时候,才执行被加载的模块(异步加载

image.png

小结:不仅要注意区分 require() vs import(),也要注意区分 import x from './xxx' 和  import (./xxx) 的差异;


我是掘金安东尼,输出暴露输入,技术洞见生活,再会~


相关文章
|
10天前
export 与 import | ES6
export 与 import | ES6
15 0
export 与 import | ES6
|
1月前
|
JavaScript 前端开发
JS require 与 import 的区别
JS require 与 import 的区别
19 1
|
5月前
|
JavaScript 前端开发
JS中 require 与 import 的区别
JS中 require 与 import 的区别
|
4月前
|
前端开发 JavaScript Python
好用的import: Vite的Glob 导入
好用的import: Vite的Glob 导入
111 0
ImportError: cannot import name ‘options‘ from ‘pyecharts‘
ImportError: cannot import name ‘options‘ from ‘pyecharts‘
485 0
ImportError: cannot import name ‘options‘ from ‘pyecharts‘
|
10月前
|
Python
flask中遇到ImportError: cannot import name ‘url_encode‘ from ‘werkzeug‘
flask中遇到ImportError: cannot import name ‘url_encode‘ from ‘werkzeug‘
280 0
|
12月前
|
JavaScript 前端开发
js中的import和export
# 引言 我们在开发时,如果将 JavaScript 加载到页面中,通常是以小片段的形式提供效果和交互,一般会把所有的 JavaScript 代码全都写在一个文件中,并加载到一个 `script` 标签中。尽管可以把 JavaScript 拆分为多个文件,但是所有的变量和函数仍然会被添加到全局作用域中。 由此我们需要使用第三方代码来完成常见任务,并且需要把代码分解为模块化的文件,避免污染全局命名空间。 ECMAScript 2015 规范在 JavaScript 语言中引入了 *module*,也有了 import 和 export 语句。 `import`和`eport`声明共同作用
|
12月前
|
Python
解决ImportError: cannot import name ‘NoReturn‘报错
解决ImportError: cannot import name ‘NoReturn‘报错
520 0
|
JavaScript
JS之export and import (详细介绍)
JS之export and import (详细介绍)
183 0
JS之export and import (详细介绍)
ImportError: cannot import name ‘Page‘ from ‘pyecharts‘
ImportError: cannot import name ‘Page‘ from ‘pyecharts‘
407 0
ImportError: cannot import name ‘Page‘ from ‘pyecharts‘