javascript中导出与导入实现模块化管理教程


Posted in Javascript onDecember 03, 2020

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

javascript中的导出和导入实现模块化管理

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'

到此这篇关于javascript中导出与导入实现模块化管理教程的文章就介绍到这了,更多相关javascript导出与导入模块化管理内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
JavaScript 动态生成方法的例子
Jul 22 Javascript
用Greasemonkey 脚本收藏网站会员信息到本地
Oct 26 Javascript
javascript常见用法总结
May 22 Javascript
Javascript日期格式化format函数的使用方法
Aug 30 Javascript
Vue自定义图片懒加载指令v-lazyload详解
Dec 31 Javascript
php register_shutdown_function函数详解
Jul 23 Javascript
JavaScript闭包的简单应用
Sep 01 Javascript
JS实现运动缓冲效果的封装函数示例
Feb 18 Javascript
在ES5与ES6环境下处理函数默认参数的实现方法
May 13 Javascript
详解封装基础的angular4的request请求方法
Jun 05 Javascript
vue学习之Vue-Router用法实例分析
Jan 06 Javascript
JavaScript实现alert弹框效果
Nov 19 Javascript
JS如何实现在弹出窗口中加载页面
Dec 03 #Javascript
对vue生命周期的深入理解
Dec 03 #Vue.js
在实例中重学JavaScript事件循环
Dec 03 #Javascript
js 数据类型判断的方法
Dec 03 #Javascript
用vue设计一个日历表
Dec 03 #Vue.js
JS闭包原理及其使用场景解析
Dec 03 #Javascript
实用的 vue tags 创建缓存导航的过程实现
Dec 03 #Vue.js
You might like
完美解决PHP中的Cannot modify header information 问题
2013/08/12 PHP
初识php MVC
2014/09/10 PHP
PHP中使用Session配合Javascript实现文件上传进度条功能
2014/10/15 PHP
Zend Framework教程之Bootstrap类用法概述
2016/03/14 PHP
PHP 生成微信红包代码简单
2016/03/25 PHP
JavaScript 验证浏览器是否支持javascript的方法小结
2009/05/17 Javascript
javascript处理table表格的代码
2010/12/06 Javascript
javascript学习笔记(十三) js闭包介绍(转)
2012/06/20 Javascript
JS实现网页背景颜色与select框中颜色同时变化的方法
2015/02/27 Javascript
js实现简易的单数字随机抽奖(0-9)
2020/03/19 Javascript
基于jQuery实现网页打印功能
2015/12/01 Javascript
jQuery自动完成插件completer附源码下载
2016/01/04 Javascript
js 弹出对话框(遮罩)透明,可拖动的简单实例
2016/07/11 Javascript
AngularJS基础 ng-hide 指令用法及示例代码
2016/08/01 Javascript
jQuery 判断是否包含在数组中Array[]的方法
2016/08/03 Javascript
Bootstrap Table使用整理(三)
2017/06/09 Javascript
详解如何让Express支持async/await
2017/10/09 Javascript
详解react、redux、react-redux之间的关系
2018/04/11 Javascript
vue中使用 pako.js 解密 gzip加密字符串的方法
2019/06/10 Javascript
vue-cli脚手架引入弹出层layer插件的几种方法
2019/06/24 Javascript
JS实现简单随机3D骰子
2019/10/24 Javascript
Vue学习之常用指令实例详解
2020/01/06 Javascript
JS数组方法push()、pop()用法实例分析
2020/01/18 Javascript
Python库urllib与urllib2主要区别分析
2014/07/13 Python
详谈Python2.6和Python3.0中对除法操作的异同
2017/04/28 Python
对pandas里的loc并列条件索引的实例讲解
2018/11/15 Python
Python定义函数功能与用法实例详解
2019/04/08 Python
python自动化UI工具发送QQ消息的实例
2019/08/27 Python
Python turtle库绘制菱形的3种方式小结
2019/11/23 Python
Python 过滤错误log并导出的实例
2019/12/26 Python
django3.02模板中的超链接配置实例代码
2020/02/04 Python
屈臣氏越南官网:Watsons越南
2021/01/14 全球购物
优秀员工自荐书
2013/12/19 职场文书
我的中国梦演讲稿小学篇
2014/08/19 职场文书
python第三方网页解析器 lxml 扩展库与 xpath 的使用方法
2021/04/06 Python
Python基础之元编程知识总结
2021/05/23 Python