Vue.js——前端模块化雏形和CommonJS——2020.12.9

一丶匿名函数的解决方案

(一)我们可以使用匿名函数来解决方面的重名问题

  • 在A.js文件中,我们使用匿名函数
    (function(){
        var flag = true
    })()

(二)但是如果我们希望在main.js文件中,用到flag,应该如何处理呢?

  • 显然,另外一个文件中不容易使用,因为flag是一个局部变量

二丶使用模块作为出口

(一)我们可以使用将需要暴露到外面的变量,使用一个模块作为出口
(二)操作步骤

  • 在匿名函数内部,定义一个空对象
  • 给对象添加各种需要暴露到外面的属性和方法(不需要暴露的直接定义即可)
  • 最后将这个对象返回,并且在外面使用一个MoudleA接受

(三)接下来,我们在main.js中怎么使用呢?

  • 我们只需要使用属于自己模块的属性和方法即可

(四)这就是模块最基础的封装,事实上模块的封装还有很多高级的话题

  • 但是我们这里就是要认识一下为什么需要模块,以及模块的原始雏形
  • 幸运的是,前端模块化开发已经有了很多既有的规范,以及对应的实现方案

(五)常见的模块化规范:

  • CommonJS
  • AMD
  • CMD
  • ES6的Modules

(六)代码详解

var ModuleA = (function(){
    // 1.定义一个对象
    var obj = {}
    // 2.在对象内部添加变量和方法
    obj.flag = true
    obj.myFunc = function(info){
        console.log(info);
    }
    // 3.将对象返回
    return obj
})()
    if (ModuleA.flag){
        console.log('key');
    }
    ModuleA.myFunc('Ting')

    console.log(ModuleA);

三丶CommonJS

(一)模块化的两个核心:导入和导出
(二)CommonJS的导出:

    module.exports = {
        flag : true,
        test(a,b){
            return a,b
        },
        demo(a,b){
            return a*b
        }
    }

(三)CommonJS的导入:

// CommonJS模块
let {test,demo,flag} = require('moduleA');

// 等同于
let _mA = require('moduleA');
let test = _mA.test;
let demo = _mA.demo;
let flag = _mA.flag;
——欲渡黄河冰塞川,将登太行雪满山——
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Blockchain_KT

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值