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

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

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

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

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

export:用于对外输出本模块

方法1 声明时直接导出


   
  1. export var str = '1';
  2. export function func1() {
  3.     return 'hello word'
  4. export const func2 = () => {
  5.     // 箭头函数导出
  6.     return 'hello word'
  7. }

方法2 统一在最后导出


   
  1. var str = '1';
  2. function func1() {
  3.     return 'hello word'
  4. }
  5. const func2 = () => {
  6.     return 'hello word'
  7. }
  8. export {
  9.     str,
  10.     func1,
  11.     func2,
  12. }

方法3 起别名


   
  1. var str = '1';
  2. function func1() {
  3.     return 'hello word'
  4. }
  5. const func2 = () => {
  6.     return 'hello word'
  7. }
  8. export {
  9.     str as str1,
  10.     func1 as f1,
  11.     func2 as f2,
  12. }

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

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


   
  1. // 这是一个utils.js 导出一个变量两个方法
  2. var str = '1';
  3. function func1() {
  4.     return 'hello word'
  5. }
  6. const func2 = () => {
  7.     return 'hello word'
  8. }
  9. export {
  10.     str as str1,
  11.     func1 as f1,
  12.     func2 as f2,
  13. }
  14. // 这是引用utils.js的文件-config.js
  15. export {str,func1,func2} from './config.js'

方法5 默认导出(default)

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

export default function() {}
  

方法6 导出类


   
  1. // 这是一个utils.js 导出一个变量两个方法
  2. export class utils {
  3.     format(){
  4.         // 类方法1
  5.     };
  6.     cheackData(){
  7.         // 类方法2
  8.     }
  9. }
  10. // 调用utils文件中
  11. import {utils} from './utils.js'
  12. const utils = new utils();
  13. utils.format();
  14. 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 一次导入文件中所有


   
  1. import * as utils from './utils.js'
  2. utils.str
  3. utils.func1
  4. utils.func2

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

import utils from './utils.js'
  

文章来源: blog.csdn.net,作者:NMGWAP,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/NMGWAP/article/details/125067185

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。