0

0

javascript模块是什么_如何导入导出功能

夢幻星辰

夢幻星辰

发布时间:2026-01-11 11:42:08

|

424人浏览过

|

来源于php中文网

原创

javascript模块是带export/import的独立文件,具有静态解析、独立作用域、顶层this为undefined等特性,需显式声明type="module",支持命名导出和默认导出,路径必须带扩展名或相对前缀,不支持动态export和裸包名直接导入。

javascript模块是什么_如何导入导出功能

JavaScript 模块就是带 exportimport 的独立文件

它不是语法糖,也不是运行时拼接的字符串——模块在加载时就确定依赖关系,有独立作用域、顶层 thisundefined、不自动提升 var 声明。浏览器和 Node.js 都原生支持,但必须显式声明类型:<script type="module"></script>"type": "module"package.json 中。

export 有命名导出和默认导出两种写法,不能混用同一变量

命名导出适合导出多个值(函数、类、常量),导入时必须用大括号;默认导出每个模块只能有一个,导入时可自定义名称,无需大括号。常见错误是试图对同一个标识符既命名导出又默认导出:

export const utils = { foo: 1 };
export default utils; // ✅ 合法:导出的是两个不同绑定
// export utils; // ❌ 语法错误:没有 default 关键字
  • export function foo() {} → 导入需 import { foo } from './x.js'
  • export default function() {} → 导入可写 import bar from './x.js'bar 是任意名)
  • export { foo as bar } 可重命名导出,import { bar } from './x.js'
  • 动态 export 不被支持,所有导出必须是顶层静态声明

import 路径必须带扩展名或以 /./../ 开头

ESM 规范禁止省略扩展名(如 import './utils' 会报错),也不能用纯包名不加 node_modules 解析逻辑(除非用构建工具或 Node.js 的 exports 字段)。浏览器中路径解析基于当前 HTML 的 URL,Node.js 则按文件系统相对路径查找:

新力企业站
新力企业站

我们的目标:麻雀虽小,五脏俱全!致力于打造互联网上程序最小功能齐全的网站源码,只要你会打字就会做网站和管理网站。任何个人和组织不得用于商业用途,本网站专业为你订做网站。1.本网站程序是基于asp 上的,本程序由新力完成,版权归新力所有.2.本网站程序功能齐全,功能强大!3.本网站程序可符合百度谷歌更新标准。4.本网站程序模板可以导入,导出,便于快速更新模板。5.本网站程序适合初学者到程序高手都可以

下载
import { helper } from './helper.js'; // ✅ 必须 .js
import { api } from '../lib/api.mjs'; // ✅ 允许 .mjs
import React from 'react'; // ✅ 仅当有 package.json "exports" 或运行在支持 bare specifier 的环境(如 Deno、Vite)
  • 不支持 import 'lodash' 在原生浏览器脚本中直接使用
  • import('./dynamic.js') 是动态导入,返回 Promise,可用于条件加载
  • 路径别名(如 @/components)需构建工具(Vite、Webpack)配置,原生 ESM 不识别

Node.js 中启用模块需注意 type 字段和文件后缀冲突

如果 package.json 里写了 "type": "module",所有 .js 文件都被当作 ESM;反之,若没写,则只有 .mjs 是 ESM,.cjs 强制为 CommonJS。二者不能混用:import 不能在 .cjs 里写,require() 不能在 .mjs 里调用。

立即学习Java免费学习笔记(深入)”;

  • 错误示例:package.jsontype,但 index.js 写了 import → 报 Cannot use import statement outside a module
  • 解决方式二选一:加 "type": "module",或把文件改成 index.mjs
  • __dirname__filename 在 ESM 中不可用,要用 import.meta.url 配合 file:// URL API
模块机制本身不处理循环依赖的执行顺序,只保证导出对象的引用一致性;真正容易出问题的是副作用初始化时机和顶层 await 的执行链。这些细节不在基础导入导出范围内,但一旦模块里有 console.log 或 API 调用,就立刻暴露出来。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

452

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

329

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1561

2023.10.24

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

507

2023.11.27

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

313

2024.02.23

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

4

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.7万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号