JavaScript中的命名导出(暴露)

在 JavaScript / React 中,"分别暴露 "和"统一暴露"是两种常用的模块导出方式。下面我来清晰地解释它们的区别,并给出示例:


✅ 一、分别暴露(命名导出)

每个变量或函数分别用 export 导出。

📦 示例:

复制代码
// utils.js
export const sum = (a, b) => a + b;
export const multiply = (a, b) => a * b;

✅ 导入方式:

复制代码
import { sum, multiply } from './utils';

✅ 特点:

  • 可以只导入其中一部分:

    复制代码
    import { sum } from './utils';
  • 必须使用原名称导入 ,除非使用 as 重命名:

    复制代码
    import { sum as add } from './utils';

✅ 二、统一暴露(也是命名导出)

先定义,再统一用 export {} 导出。

📦 示例:

复制代码
// utils.js
const sum = (a, b) => a + b;
const multiply = (a, b) => a * b;

export { sum, multiply };

✅ 导入方式:

复制代码
import { sum, multiply } from './utils';

✅ 特点:

  • 功能和"分别暴露"一样,只是语法结构不同。

  • 统一书写更方便管理导出列表。


✅ 三、默认暴露(default export)

每个模块只能有一个 export default

📦 示例:

复制代码
// MyComponent.jsx
export default function MyComponent() {
  return <div>Hello</div>;
}

✅ 导入方式:

复制代码
import MyComponent from './MyComponent';

✅ 特点:

  • 导入时可以使用任意名称(默认导出不需要花括号):

    复制代码
    import Anything from './MyComponent'; // 合法

✅ 四、混合使用(不推荐)

复制代码
// utils.js
export const sum = () => {};
export default function main() {}

可以这样导入:

复制代码
import main, { sum } from './utils';

👉 尽量避免这样写,容易引起混淆。


✅ 总结表格:

类型 写法示例 导入方式 特点
分别暴露 export const a = 1; import { a } from './x' 可多次写、导入时必须加花括号
统一暴露 export { a, b }; import { a } from './x' 统一管理、导入规则同分别暴露
默认暴露 export default function() {} import x from './x' 只允许一个、导入时不加花括号

如果你是写组件库或者模块工具,推荐使用:

  • 组件:默认导出

  • 工具函数:命名导出(统一导出更整洁)

相关推荐
jingling55511 分钟前
解决微信小程序真机调试中访问本地接口 localhost:8080 报错
前端·微信小程序·小程序
en-route12 分钟前
使用 Flask 构建 Web 应用:静态页面与动态 API 访问
前端·python·flask
IT_陈寒14 分钟前
Vite 5年迭代揭秘:3个核心优化让你的项目构建速度提升200%
前端·人工智能·后端
怎么吃不饱捏30 分钟前
vue3+vite,引入阿里巴巴svg图标,自定义大小颜色
前端·javascript·vue.js
无敌最俊朗@31 分钟前
MQTT 关键特性详解
java·前端·物联网
JAVA学习通31 分钟前
微服务项目->在线oj系统(Java-Spring)----[前端]
java·开发语言·前端
excel36 分钟前
Vue3 响应式系统核心执行器:Reactive Effect 与依赖调度机制
前端
南玖i2 小时前
vue3 通过 Vue3DraggableResizable实现拖拽弹窗,可修改大小
前端·javascript·vue.js
excel3 小时前
Web发展与Vue.js导读
前端
YAY_tyy3 小时前
Three.js 开发实战教程(五):外部 3D 模型加载与优化实战
前端·javascript·3d·three.js