命名导出和默认导出的用法区别

背景:

1、在编写代码的时候,build打包报警告,使用GPT询问之后得到命名导出和默认导出的区别,因此有想法去了解下命名导出和默认导出的用法区别。

复制代码
export 'default' (imported as 'store') was not found in '@/content-scripts/store' (possible exports: store)

结论:

1. 命名导出(Named Export)

  • 使用 import { store } 是导入一个 命名导出 的模块成员。
  • 命名导出允许从一个文件中导出多个不同的成员,每个成员都需要在导入时用花括号指定其名字。
命名导出示例:

store.js

复制代码
// 导出多个命名成员
export const store = {
  // store 的内容
};

export const anotherStore = {
  // anotherStore 的内容
};

导入方式:

复制代码
// 使用花括号导入指定的命名导出
import { store, anotherStore } from '@/content-scripts/store';

在这种情况下,storeanotherStore明确命名的导出,并且可以同时导入多个命名导出。

2. 默认导出(Default Export)

  • 使用 import store 是导入一个 默认导出 的模块成员。
  • 默认导出文件中只能有一个导出项,不需要花括号,并且导入时可以自定义导入名称(即导入时的名字不必与导出时的名字相同)。
默认导出示例:

store.js

复制代码
// 仅导出一个默认成员
const store = {
  // store 的内容
};

export default store;

导入方式:

复制代码
// 不使用花括号,并且可以重命名导入的内容
import store from '@/content-scripts/store';

在这种情况下,store默认导出 ,文件中只能有一个默认导出,而且导入时可以随意命名(例如你可以用 import myStore from '@/content-scripts/store' 这样的导入)。

3. 关键区别总结

  • import { store } : 用于导入 命名导出,并且必须与导出的名字完全一致,且可以同时导入多个命名成员。
  • import store : 用于导入 默认导出,只需导出一个成员,导入时可以重命名。
相关推荐
兮兮能吃能睡7 分钟前
SQL中常见的英文术语及其含义
数据库·sql·oracle
Elastic 中国社区官方博客1 小时前
根据用户行为数据中的判断列表在 Elasticsearch 中训练 LTR 模型
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
王道长服务器 | 亚马逊云3 小时前
AWS CloudWatch:服务器的“眼睛”,实时监控一切动向
服务器·数据库·aws
怪兽20145 小时前
什么是 Redis?
java·数据库·redis·缓存·面试
kyle~6 小时前
C++--- override 关键字 强制编译器验证当前函数是否重写基类的虚函数
java·前端·c++
wangmengxxw6 小时前
Redis概述
数据库·redis·缓存
笔生花6 小时前
【实战-12】flink版本表
数据库·sql·flink
Light606 小时前
像素退场,曲线登场:现代响应式 CSS 全家桶 | 领码课堂
前端·css·响应式设计·css函数·布局系统·相对单位·设计令牌
花月C6 小时前
高效查找数据的数据结构—MySQL 索引
数据结构·数据库·mysql
我笔记6 小时前
关系型数据库RDBMS与非关系型数据库NoSQL区别
数据库·oracle