JS 模块

模块化开发

特点
  • 延迟解析
  • 默认严格模式
使用步骤

1.通过export导出成员
2.在另一个文件当中通过import接收成员
3.引用通过webpack编译后生成的bundle.js文件
举例:

  • a.js
export let a = { name: "aaa" };
export const b = 111;
// 导出成员a和b
  • b.js
import * as a from './a'
// 导入a.js里的所有成员,注意相对路径需要加`./`这样的定位符
console.log(a.a, a.b);
// 输出导入的成员
  • webpack.config.js
module.exports = {
    mode: 'development',
    entry: './b.js',
    output: {
        filename: 'bundle.js',
        path: __dirname + '/build'
    }
}

导入webpack生成的文件后可以发现输出了ab的值。
注:
注意相对路径需要加./这样的定位符,因为模块化需要在node环境下使用,如果不加定位符,则默认去依赖模块当中寻找,而不会去相对路径下找

默认成员default

在模块化当中还可以导出默认成员default,则通过导入模块成功语法时,只导入默认成员default的值,举例:

  • a.js
export default "aaa";
// 导出默认成员"aaa"
  • b.js
import a from './a'
// 导入默认成员default,并命名为a,相当于下面这个意思
// import default as a from './a'

console.log(a);

这种语法在vue的组件化工程当中很常见

导入成员语法

前面介绍了两种语法,一种是导入全部:

import * as xxx from './xxx'

还有导入默认默认成员语法:

import xxx from './xxx'

如果希望导入指定的成员也可以:

import {xxx, yyy as zzz} from './xxx'
// 导入./xxx文件里的xxx和yyy成员,并将yyy改名为zzz

还有导入如CSS文件、图片文件等模块时(在模块化开发下一些静态文件都称为模块),因为这些文件里可能不存在成员啥的,所以可以只导入,举例:

import './xxx'

还有异步引入,使用import方法,举例:

let x = import('./xxx')
// 当需要用到的时候引入,简化代码体积
// 传回来的是个Promise对象,需要使用await关键字等待
模块化导入路径问题
  • 'xxx':直接从npm依赖里寻找相关模块
  • './xxx'/../xxx:从相对路径当中寻找相关模块
  • @/xxx:从src目录下寻找相关模块

其他

自定义实现模块管理
let myModule = (function() {
    const moduleMap = {};
    // 定义一个对象管理所有模块
    function define(name, dependencies, action) {
        // 定义模块方法,依次传入模块名、依赖的模块,以及对应的操作行为
        dependencies.map((dependency, index) => {
            // 获取当前模块依赖的模块
            if (!(dependency in moduleMap)) throw Error(`模块:${dependency}不存在!`)
            dependencies[index] = moduleMap[dependency];
        })
        moduleMap[name] = action(...dependencies);
        // 执行模块行为
    }
    return {
        define
    }
})();

// 定义模块math,暴露出add和sub方法
myModule.define("math", [], function() {
    return {
        add(x, y) {
            return x + y;
        },
        sub(x, y) {
            return x - y;
        }
    };
})

myModule.define("utils", [], function() {
    return {
        toLower(val) {
            return val.toLowerCase();
        }
    };
})

// 定义模块test,依赖math和utils模块,并使用这两个模块提供的方法
myModule.define("test", ["math", "utils"], function(math, utils) {
    console.log(math.add(1, 2));
    console.log(math.sub(1, 2));
    console.log(utils.toLower("Me"));
})
html里使用模块

<script>标签中设置属性type="module"即可,此时就可以用模块化相关的代码的,举例:

<script type="module">
    import { Test } from "./test.js";
    console.log(Test);
</script>
动态按需加载模块

通过import方法实现(返回promise对象),举例:

<script type="module">
    let a = 1;
    if (a === 1) {
        import("./test.js").then(data => {
            console.log(data.Test);
        })
    }
</script>

注:
因为import语句只能放在最外层,不能放在内部,所以这里使用import方法

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容