ES6的模块化规范之导入与导出

ES6的模块化系统支持使用importexport关键字导入和导出模块。

  • 使用export关键字可以将变量、函数、类等导出为一个模块。
  • 使用export default关键字可以导出一个默认的内容,每个模块只能有一个默认导出。
  • 使用import关键字可以从其他模块中导入所需的内容。
  • 使用花括号 {} 导入命名导出的内容,使用任意名称导入默认导出的内容。

默认导入和导出

默认导入:export default 默认导出的成员

javascript 复制代码
let name='张三'
let age=18
const sex='男'
const info='人物信息'
function clog(){
    console.log(name,age,sex)
}

export default{ //抛出info变量和clog方法
    info,
    clog
}

在这里导出了一个info变量和一个clog方法,info的值为一个字符串'人物信息',clog的效果是打印出name,age,sex这三个变量的值。

默认导出:import 接收名称 from '文件所处位置'

xml 复制代码
<template>
	<div>
		<text>{{ text.info }}</text>
	</div>
</template>

<script setup>
import text from './api/text';

let show= text.clog();
</script>

导入text.js中所抛出的变量info和方法clog,通过将info的值渲染到浏览器页面上以及调用clog方法来查看效果。

  • 打印效果
  • 渲染效果

注意的是: 每个模块中,只允许使用唯一的一次 export default


按需导入和按需导出

按需导出:使用export关键字导出的内容需要被命名,其他模块需要使用相同的名称进行导入。

javascript 复制代码
let name='张三'
let age=18
const sex='男'
function clog(){
    console.log(name,age,sex)
}

export const info='人物信息'
export { 
    name,
    age,
    sex
}

在这里进行了两次导出,第一次导出了info变量,第二次导出了name,age,sex这三个变量

按需导入:使用import关键字导入的内容需要与导出时使用相同的名称匹配。

xml 复制代码
<template>
	<div>
		<text>{{ name }}</text>
		<text>{{ age }}</text>
		<text>{{ sex }}</text>
	</div>
</template>

<script setup>
import {name,age,sex,info} from './api/text';

console.log(info);

</script>

在这里导入了text.js中的name,age,sex,info这四个变量,同时将name,age,sex这三个变量渲染到浏览器页面上,将info变量打印处理。

  • 如果我们引入未被导出的clog时浏览器会报出以下错误
  • 渲染效果为
  • 打印效果为

值得注意的是在按需导入中,每个模块中可以多次按需导出且按需导入的成员名称必须和按需导出的名称保持一致


总结

ES6模块化规范是ES6中引入的一种模块化系统,用于在JavaScript应用程序中组织、导入和导出代码。它提供了一种更简单、更可靠的方式来处理模块之间的依赖关系。每个模块都应该有一个独立的文件,文件名通常与导出的内容相关,模块中的代码可以使用其他模块导出的内容。

相关推荐
念念不忘 必有回响1 小时前
viepress:vue组件展示和源码功能
前端·javascript·vue.js
C澒2 小时前
多场景多角色前端架构方案:基于页面协议化与模块标准化的通用能力沉淀
前端·架构·系统架构·前端框架
崔庆才丨静觅2 小时前
稳定好用的 ADSL 拨号代理,就这家了!
前端
江湖有缘2 小时前
Docker部署music-tag-web音乐标签编辑器
前端·docker·编辑器
恋猫de小郭3 小时前
Flutter Zero 是什么?它的出现有什么意义?为什么你需要了解下?
android·前端·flutter
崔庆才丨静觅9 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby606110 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了10 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅10 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅10 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端