JavaScript中export和import实现模块化管理

简介: JavaScript中export和import实现模块化管理

在理想情况下,开发者只需要实现核心的业务逻辑,其他都可以加载别人已经写好的模块。但是,在ES6以前,JavaScript一直没有自己模块体系(module),无法将一个大程序拆分成互相依赖的小文件,再用简单的方法拼装起来。如果要想在前端做模块化开发,必须依赖第三方框架来实现,如:requireJS与seaJS。

requireJS是AMD规范的起源,seaJS是CMD规范的起源,由于两者功能高度重合,后来seaJS不再维护,从此淡出人们的视野,于是requireJS一家独大,直到ES6的出现,且迅速成为前端和服务器端通用的模块解决方案,完全可以取代AMD 规范和NodeJS支持的CommonJS 规范。

ES6中首次引入模块化开发规范ES Module,让JavaScript首次支持原生模块化开发,使用 export 和 import 关键字进行模块化开发。

1 export:用于对外输出本模块

方法1 声明时直接导出

export var str = '1';
export function func1() {
    return 'hello word'
} 
export const func2 = () => {
    // 箭头函数导出
    return 'hello word'
}

复制

方法2 统一在最后导出

var str = '1';
function func1() {
    return 'hello word'
}
const func2 = () => {
    return 'hello word'
}
export {
    str,
    func1,
    func2,
}

复制

方法3 起别名

var str = '1';
function func1() {
    return 'hello word'
}
const func2 = () => {
    return 'hello word'
}
export {
    str as str1,
    func1 as f1,
    func2 as f2,
}

复制

方法4 对导入的方法直接导出

这种方法常用于统一文件导出

// 这是一个utils.js 导出一个变量两个方法
var str = '1';
function func1() {
    return 'hello word'
}
const func2 = () => {
    return 'hello word'
}
export {
    str as str1,
    func1 as f1,
    func2 as f2,
}
// 这是引用utils.js的文件-config.js
export {str,func1,func2} from './config.js'

复制

方法5 默认导出(default)

这种导出方式一个js文件只能有一个default,所以它后面不能跟变量声明语句。

export default function() {}

复制

方法6 导出类

// 这是一个utils.js 导出一个变量两个方法
export class utils {
    format(){
        // 类方法1
    };
    cheackData(){
        // 类方法2
    }
}
// 调用utils文件中
import {utils} from './utils.js'
const utils = new utils();
utils.format();
utils.cheackData();

复制

2 import:用于在模块中加载含有export接口的模块

方法1 直接导出

import {str,func1,func2} from './utils.js'

复制

方法2 起别名

这种情况一般用于导入的两个或者多个模块中存在相同的导入内容

import {str as str1,func1 as f1,func2 as f2} from './utils.js'

复制

方法3 一次导入文件中所有

import * as utils from './utils.js'
utils.str
utils.func1
utils.func2

复制

方法4 导入使用default方式导出的模块

import utils from './utils.js'

复制

相关文章
|
2月前
|
JavaScript UED
js之模块化(2)
js之模块化(2)
|
3月前
|
JavaScript 前端开发 编译器
解锁JavaScript模块化编程新纪元:从CommonJS的基石到ES Modules的飞跃,探索代码组织的艺术与科学
【8月更文挑战第27天】随着Web应用复杂度的提升,JavaScript模块化编程变得至关重要,它能有效降低代码耦合度并提高项目可维护性及扩展性。从CommonJS到ES Modules,模块化标准经历了显著的发展。CommonJS最初专为服务器端设计,通过`require()`同步加载模块。而ES Modules作为官方标准,支持异步加载,更适合浏览器环境,并且能够进行静态分析以优化性能。这两种标准各有特色,但ES Modules凭借其更广泛的跨平台兼容性和现代语法逐渐成为主流。这一演进不仅标志着JavaScript模块化的成熟,也反映了整个JavaScript生态系统的不断完善。
50 3
|
2月前
|
JavaScript 前端开发 开发者
js之模块化(1)
js之模块化(1)
|
28天前
|
缓存 JavaScript 前端开发
Node.js模块化的基本概念和分类及使用方法
Node.js模块化的基本概念和分类及使用方法
30 0
|
2月前
|
JavaScript
js之模块化(3)
js之模块化(3)
|
3月前
|
前端开发 JavaScript
前端必会的JavaScript模块化
【8月更文挑战第3天】JavaScript模块化
28 1
|
3月前
|
存储 缓存 JavaScript
JavaScript——请列出目前主流的 JavaScript 模块化实现的技术有哪些?说出它们的区别?
JavaScript——请列出目前主流的 JavaScript 模块化实现的技术有哪些?说出它们的区别?
31 0
|
3月前
|
JSON JavaScript 前端开发
javascript import maps 特性现已被全部主流浏览器支持
javascript import maps 特性现已被全部主流浏览器支持
|
4月前
|
JavaScript
js export 对外输出常量、变量和函数
js export 对外输出常量、变量和函数
87 5
|
4月前
|
JavaScript 前端开发
node.js 导入导出模块(CommonJS模块化规范,ES6模块化规范)
node.js 导入导出模块(CommonJS模块化规范,ES6模块化规范)
51 1