js cannot use import statement outside a module
时间: 2024-06-20 10:01:49 浏览: 183
在 JavaScript 中,`import` 语句用于导入模块(module)中的内容,这是 ES6 引入的一个现代特性。`import` 语句只能在模块内部使用,也就是说,它不能直接在全局作用域(如浏览器的全局 window 对象或 Node.js 的全局模块中)使用。
当你试图在非模块文件(比如一个普通的 `.js` 文件,而不是一个被 `export` 和 `import` 包装的模块文件)中使用 `import`,JavaScript 解释器会报错,提示你 "cannot use import statement outside a module"。这是因为 JavaScript 的模块系统要求每个文件都是独立的,有自己的作用域,它们之间通过导出和导入进行交互。
为了正确使用 `import`,你需要将你的代码组织成模块形式,例如创建一个名为 `myModule.js` 的文件:
```javascript
// myModule.js
export const myVariable = 'Hello, world!';
export function myFunction() {
// ...
}
```
然后在另一个模块中导入这个内容:
```javascript
// main.js
import { myVariable, myFunction } from './myModule.js';
console.log(myVariable); // 输出 "Hello, world!"
myFunction(); // 调用函数
```
如果你在一个单独的文件里想导入,你需要通过构建工具(如 Webpack、Rollup 或 esm-loader)或在 Node.js 中使用 `require()` 替代。
阅读全文