ES模块导入、导出学习笔记
1、命名导出、导入
1.1、声明时直接导出
- 导出
/**
* 定义一个变量
*/
export const src = "我是一个字符串";
/**
* 定义一个函数
*/
export const func = function () {
console.log("我是一个函数");
};
- 导入
// 分别导入
import { src, func } from "@/common/index";
onMounted(() => {
// 打印变量
console.log(src, "打印变量");
// 调用函数
func();
});
1.2、先声明,再导出
- 导出
/**
* 定义一个变量
*/
const src = "我是一个字符串";
/**
* 定义一个函数
*/
const func = function () {
console.log("我是一个函数");
};
export { src, func };
- 导入
// 分别导入
import { src, func } from "@/common/index";
onMounted(() => {
// 打印变量
console.log(src, "打印变量");
// 调用函数
func();
});
2、默认导出、导入
2.1、声明时直接导出
- 默认导出跟命名导出的区别:
- 默认导出比命名导出多一个default关键字
- 默认导出可以省略函数名
- 导出
/**
* 定义一个函数
*/
export default function func() {
console.log("我是一个函数");
}
- 导入
// 导入默认导出的方法,方法名随便
import func from "@/common/index";
onMounted(() => {
// 调用函数
func();
});
2.2、先声明,再导出
- 导出
/**
* 定义一个变量
*/
const src = "我是一个字符串";
/**
* 定义一个函数
*/
function func() {
console.log("我是一个函数");
}
export default { src, func };
- 导入
import common from "@/common/index";
onMounted(() => {
// 调用变量
console.log(common.src);
// 调用函数
common.func();
});
3、命名导出 VS 默认导出
3.1、命名导出
- 可以导出多个值,并且可以选择性导入,灵活性更好
- 指定了确切的名字,便于代码追踪和维护
- 适合有多个功能的模块
3.2、默认导出
- 简化了单个值的导入和导出,可以让代码更加简洁
- 适合功能单一的模块
1、 命名导出:导入的时候需要花括号({})。
2、 默认导出:导入的时候不需要花括号({})。
3.3、同时使用
- 导出
export const common = {
src: "我是一个字符串",
func: function () {
console.log("我是一个函数");
},
};
export default function func2() {
console.log("我是一个默认函数2");
}
- 导入
import func2, { common } from "@/common/index";
onMounted(() => {
// 调用变量
console.log(common.src);
// 调用函数
common.func();
// 调用函数
func2();
});
4、使用 as 关键字
- 功能:用于重命名导入或导出的值
- 使用场景:解决名称冲突、适用当前上下文,提高可读性
4.1、在 import 中使用 as
- 假设 common 中 func 函数是命名导出
import { func as sayHandle } from '@/common/index'
- 假设 common 中 func 函数是默认导出
import { default as sayHandle } from '@/common/index'
- 将 module 中的所有导出内容聚合到 module 对象中
import * as module from '@/common/index'
// 使用方法
console.log(module.func())
4.2、在 export 中使用 as
function func(name){
return `Hello,${name}!`
}
export { func as sayHandle }
// 或者将 func 函数默认导出
// 和 == export default func == 是一样的效果
export { func as default }
5、动态导入
- 示例1:
import("@/common/index").then((module)=>{
console.log(module.func())
})
- 示例2:
const module = await import("@/common/index")
consolg.log(module.func())