require
和import
都是JavaScript中用于模块化的关键字,但是它们在使用上有一些区别。
require
是CommonJS规范中用于引入模块的关键字,一般用于Node.js环境。它是同步加载模块,将整个模块的内容放入一个对象中,通过对象的属性来访问模块中的方法和变量。例如:
const math = require('./math');
console.log(math.add(2, 3));
import
是ES6 Module规范中用于引入模块的关键字,一般用于现代浏览器和Node.js环境。它是异步加载模块,只会加载需要的部分,可以直接导入模块中的方法和变量。例如:
import { add } from './math';
console.log(add(2, 3));
除了使用方式上的不同,它们还有以下区别:
require
可以在模块的任何位置调用,而import
只能在模块的顶部调用。require
是动态的,可以在运行时根据需要加载模块,而import
是静态的,必须在编译时就确定要加载哪些模块。require
返回的是一个对象,需要通过对象属性来访问模块中的方法和变量,而import
可以直接导入模块中的方法和变量。
总的来说,require
和import
都是用于JavaScript模块化的关键字,但是它们在使用方式和规范上有所不同。