export,import ,export default区别

本文详细介绍了ES6模块的两个核心功能:export和import。通过具体的代码示例展示了如何在不同文件间导出和导入变量、函数等内容,并解释了export与exportdefault的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ES6模块主要有两个功能:export和import
export用于对外输出本模块(一个文件可以理解为一个模块)变量的接口
import用于在一个模块中加载另一个含有export接口的模块。
也就是说使用export命令定义了模块的对外接口以后,其他JS文件就可以通过import命令加载这个模块(文件)。这几个都是ES6的语法。

export和import(一个导出一个导入)

一个a.js文件有如下代码:

export var name="李四";

在其它文件里引用如下:

复制代码
import { name } from "/.a.js" //路径根据你的实际情况填写
export default {
  data () {
    return { }
  },
  created:function(){
    alert(name)//可以弹出来“李四”
  }
 }
复制代码

上面的例子是导出单个变量的写法,如果是导出多个变量就应该按照下边的方法,用大括号包裹着需要导出的变量:

 var name1="李四";
 var name2="张三";
 export { name1 ,name2 }

在其他文件里引用如下:

复制代码
import { name1 , name2 } from "/.a.js" //路径根据你的实际情况填写
export default {
  data () {
    return { }
  },
  created:function(){
    alert(name1)//可以弹出来“李四”
    alert(name2)//可以弹出来“张三”
  }
 }
复制代码

如果导出的是个函数呢,那应该怎么用呢,其实一样,如下

function add(x,y){
   alert(x*y)
  //  想一想如果这里是个返回值比如: return x-y,下边的函数怎么引用
}
export { add }

在其他文件里引用如下:

复制代码
import { add } from "/.a.js" //路径根据你的实际情况填写
export default {
  data () {
    return { }
  },
  created:function(){
   add(4,6) //弹出来24
  }
 }
复制代码

export与export default

看完上面这几个例子,想必你一定了解了如何使用export,import,如果还是不懂可以自己动手试一试。上面讲的是export和import,但是export跟export default 有什么区别呢?如下:

1、export与export default均可用于导出常量、函数、文件、模块等
2、你可以在其它文件或模块中通过import+(常量 | 函数 | 文件 | 模块)名的方式,将其导入,以便能够对其进行使用
3、在一个文件或模块中,export、import可以有多个,export default仅有一个
4、通过export方式导出,在导入时要加{ },export default则不需要

这样来说其实很多时候export与export default可以实现同样的目的,只是用法有些区别。注意第四条,通过export方式导出,在导入时要加{ },export default则不需要。使用export default命令,为模块指定默认输出,这样就不需要知道所要加载模块的变量名。

复制代码
var name="李四";
export { name }
//import { name } from "/.a.js" 
可以写成:
var name="李四";
export default name
//import name from "/.a.js" 这里name不需要大括号
复制代码

 

再看第3条,在一个文件或模块中,export、import可以有多个,export default仅有一个,也就是说如下代码:

var name1="李四";
var name2="张三";
export { name1 ,name2 }

 

也可以写成如下,也是可以的,import跟他类似。

 var name1="李四";
 var name2="张三";
 export name1;
 export name2;
<think>好的,我需要回答用户关于JavaScript中importexport default用法的问题。首先,用户提供的引用内容已经涵盖了基本用法区别,我需要将这些信息整理成结构清晰的教程。 第一步,要明确exportexport default的基本概念。根据引用[2][3],export default用于模块的默认导出,每个模块只能有一个默认导出,而export可以导出多个命名导出。需要强调两者的区别,比如导入时是否需要使用花括号。 接下来,应该分点说明使用方法。比如,先介绍export default的用法,再讲export,然后对比两者的差异。同时,需要给出实际的代码示例,帮助用户理解。例如,引用[3]中提到导出函数、变量,这时候可以举一个导出函数变量的例子,并展示如何导入。 然后,要注意特殊情况,比如混合使用默认导出命名导出。引用[1]提到重新导出时可能忽略默认导出,这点需要提醒用户注意。可能需要一个示例说明如何正确导出默认命名导出。 还要强调导入时的语法差异。根据引用[2],使用export导出的内容需要加花括号,而export default不需要。这部分需要明确说明,避免混淆。 最后,总结最佳实践,比如推荐使用export按需导入以减小项目体积,如引用[3]所述。同时,可以提到常见错误,比如重复默认导出或导入时忘记花括号,帮助用户避免问题。 需要确保所有代码示例正确,并符合用户提供的LaTeX格式要求,行内代码用$...$,独立代码块用```包裹。同时,生成的相关问题要围绕模块导出导入的扩展知识,比如差异、最佳实践、循环依赖等。 现在组织内容,确保结构清晰,分步骤讲解,并自然融入引用标注。检查是否有遗漏的要点,比如重新导出的注意事项,以及默认导出的使用场景。完成后,生成相关问题,帮助用户进一步学习。</think>### JavaScript中`import`与`export default`使用教程 #### 一、基本概念 1. **`export default`** 用于导出模块的**默认值**,一个模块中**只能有一个默认导出**。导入时不需要使用花括号,且可以自定义导入名称[^2][^3]。 示例: ```javascript // math.js const add = (a, b) => a + b; export default add; // main.js import customName from './math.js'; // 导入时可自定义名称 ``` 2. **`export`** 用于导出**命名变量/函数**,一个模块可以有多个命名导出。导入时需使用花括号,且名称必须与导出时一致[^2][^3]。 示例: ```javascript // utils.js export const PI = 3.14; export const square = x => x * x; // main.js import { PI, square } from './utils.js'; // 必须用{}且名称固定 ``` --- #### 二、混合使用默认导出与命名导出 若模块同时包含默认导出命名导出,导入时需分开处理: ```javascript // config.js export const API_KEY = '123'; export default { env: 'production' }; // main.js import config, { API_KEY } from './config.js'; // config对应默认导出,API_KEY是命名导出 ``` --- #### 三、重新导出的注意事项 通过`export * from 'module'`重新导出时,**会忽略原模块的默认导出**,需显式处理[^1]: ```javascript // 错误示例:默认导出丢失 export * from './user.js'; // 正确示例:保留默认导出 export { default } from './user.js'; export * from './user.js'; ``` --- #### 四、最佳实践 1. **按需导入** 使用`export`导出多个功能,导入时选择需要的部分,减少代码体积[^3]。 2. **默认导出的场景** 适用于模块主要功能单一的情况(如工具类、配置对象)。 3. **避免重复导出** 同一模块不要混合使用多个`export default`,会导致错误。 --- #### 五、常见错误 1. **导入名称不匹配** ```javascript // 错误 import { add } from './math.js'; // math.js中使用的是export default // 正确 import add from './math.js'; ``` 2. **忽略默认导出的重新导出** 如第三部分所述,需显式处理默认导出。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值