详解ES6的导入和导出

前言

ES6模块化规范中定义:ES6 模块化规范 浏览器端和服务器端通用的模块化开发规范

ES6的导入和导出是指在ES6规范中引入的模块化系统,用于更好地组织、管理和重用JavaScript代码。这一模块化系统提供了两个关键字:import 用于导入模块中的成员,export 用于将模块中的成员导出,使其可供其他模块使用。

  1. 每一个JS文件都是一个独立的模块
  2. 导入其它模块成员使用 import 关键字
  3. 向外共享模块成员使用 export 关键字

默认导入和默认导出

默认导出语法:export default 默认导出的成员

js 复制代码
// ./out.js
let name = '张三';
let age = 21;
function show() {
    console.log(name, age);
}
// 默认导出name和show方法
export default {
    name,
    show
}

默认导入语法:import 接收名称 from '模块标识符'

js 复制代码
// App.vue
// 默认导入
import test from './default';
test.show();
//输出结果为:
// 张三 21

注意: 每个模块中只允许使用唯一的一次 export default,默认导入时的接收名称可以是任意合法名称。

按需导出与按需导入

按需导出语法:export 导出的属性或方法

js 复制代码
// ./need.js
export let name = '张三';
let age = 21;
export let gender = '男';
export function show() {
    console.log(name, age, gender);
}

按需导入语法:import {对应的属性名或方法} from '模块标识符'

js 复制代码
// App.vue
// 按需导入
import { name, show } from '.need';
show();
// 输出结果
// 张三 21 男

注意 :

  • 每个模块中可以使用多次按需导出。
  • 按需导入的成员名称必须和按需导出的名称保持一致。
  • 按需导入时,可以使用 as 关键字进行重命名。

直接导入并执行模块中的代码

js 复制代码
// ./direct.js
let name = '张三';
let age = 21;
let gender = '男';
console.log(name, age,gender);
js 复制代码
// App.vue
// 直接导入并执行
import './direct';
// 输出结果:张三 21 男

结语

总结:

  • 默认导出 :模块中只允许使用唯一的一次 export default,默认导入时可以选择使用任意合法名称。
  • 默认导入 :导入的成员被命名为 test,是默认导出模块的整个对象。
  • 按需导出 :可以多次使用 export 关键字导出模块中的成员。
  • 按需导入 :导入的成员名称必须和导出时的名称保持一致,也可以使用 as 关键字进行重命名。
  • 直接导入并执行:用于执行模块中的全局代码,不需要显式导入任何成员,只需导入模块本身。
  • 注意: 直接导入并执行方式主要用于模块中包含一些全局执行的代码,而不是导出特定的成员。

总的来说默认导出与默认导入适用于导出模块的整个对象,导入时可以选择使用任意合法名称。 按需导出与按需导入适用于有选择性地导入模块中的特定成员,可以多次导出和导入,支持重命名。 直接导入并执行适用于执行模块中的全局代码,不需要显式导入成员,只需导入模块本身。

相关推荐
kyriewen28 分钟前
面试8家前端岗位后,我发现了一个残酷的事实:AI不是加分项,是门槛
前端·javascript·面试
MageGojo3 小时前
做节日活动页时,如何用 API 快速生成对联内容
javascript·python·节日·对联生成
向上的车轮3 小时前
Next.js 入门指南:从零到一构建全栈应用
开发语言·javascript·ecmascript
freeinlife'4 小时前
精准秒表计时器实现---基于js
开发语言·前端·javascript
MaCa .BaKa4 小时前
55-宠物爱心救助领养系统-宠物救助领养系统
java·vue.js·tomcat·maven·springboot·宠物救助领养系统
优雅格子衫4 小时前
uniapp 拍照相册选取后超级好用的裁剪组件,增加水印完全自定义
开发语言·前端·javascript·uni-app·vue
AI砖家4 小时前
前端 JavaScript 异步处理全方案详解:从回调到 Observable
开发语言·前端·javascript
柒和远方5 小时前
每日一学V010: 从 Python 回到前端:一个 AI Native 开发者的 JavaScript 底层基础补全
javascript
之歆5 小时前
Day21_电商详情页核心技术实战:从LESS预处理到复杂交互实现
开发语言·前端·javascript·css·交互·less
海鸥两三5 小时前
基于 Vue 3 + 高德地图的网格规划系统实战(有源码)
前端·javascript·vue.js