2019-08-24

模块化

什么是模块?

一个具有处理逻辑的js文件,把相关的方法或对象进行导出,经过导入就可以使用.

模块化有什么作用?

  • 避免命名冲突(减少命名空间污染)
  • 更好的分离, 按需加载
  • 更高复用性
  • 高可维护性
  • 分治(你会发现当逻辑复杂的时候,可以分得更加细的模块,而且多人同时开发,可见分治是模块化最大的优点。)

为什么要用模块化?

那么webpack提出来的,万物都是模块化.比如一个项目越做越大,项目也变得越来越难维护,JavaScript模块化,把每个单独的可复用性的业务逻辑抽离出来成为一个个模块,需要用到的时候直接导入,进行使用,一处编写处处使用,以后业务需要更新,只需要改模块的逻辑即可.我们项目肯定会封装一个异步请求的js文件,使用的时候代码非常精简,舒服.

在ES6之前,javascript是不是没有模块体系,javascript社区制定的CommonJS,AMD,CMD.都是不是我们真正需要的,直到ES6提出来的模块化—ES6模块

<font color="red" size=3>主角放在前面 👇👇👇</font>

主角ES6 模块

在 ES6 前, 实现模块化使用的是 RequireJS (基于 AMD 规范的模块化库)或者 seaJS(基于 CMD 规范的模块化库)。直到ES6模块出来了,他们就被取代了, 新王登基。

严格模式:模块化自动是严格模式,总之我们老老实实写,不会报错了啦.

**export(导出): **规定模块的对外导出的接口

import(导入): 规定模块的对外导入的接口

实践一下怎么使用

导出:

//写一个逻辑代码,这是js文件===模块
function atoe(params) {
    console.log("这是模块中的逻辑代码",params); 
}

export { //导出
    atoe,           //方式一:将函数暴露出去 
    atoe as newAtoe //方式二: 将newAtoe暴露出去,然而newAtoe引用了atoe,达到了重命名的效果
    //所以这里总共导出了 atoe 和 newAtoe到外面.
}  

导入:

    //组件中使用,我以vue为例子.其他也一样的.
//这是要使用的时候导入,
<template>
  <div>
    <button @click="runAtoe('msg')">HelloWorld</button>
  </div>
</template>

<script>
  //导入方式一:这种叫做按需导入方法,物尽其用.赞成👍
import {atoe, newAtoe} from '../js/atoeModule'
export default {
  methods: {
    runAtoe(params){
      atoe(params);
      newAtoe(params);
    }
  },
}
</script>

<script>
  //导入方式二:整体导入,这种不管三七二十一,全部导过来,然后这里把他们都放在了allFn这个对象里面,然后通过对象获取他们,也没有说这种不行就是low
import * as allFn from '../js/atoeModule'
export default {
  methods: {
    runAtoe(params){
      allFn.atoe(params);
      allFn.newAtoe(params);
    }
  },
}
</script>
注意这两种做法没有性能差别,因为ES6模块是静态加载,只是一个引用,不会在内存中造成负担.

刚刚上面介绍的是非常合情理的导入导出.但是为了照顾哪些心急的人,往往也需要添加一些东西,来满足他们的需求

export default: 默认导出,它能带来的好处就是<font color="red" size=3>一次导出(只能导出一次)</font>,导出的时候只要路径对了,不管你取什么名字,都可以使用.

导出:

//写一个逻辑代码
function atoe(params) {
    console.log("这是模块中的第一个逻辑代码",params); 
}

function atoe2(params) {
    console.log("这是模块中的第二个逻辑代码",params); 
}

export default{ //默认导出
    atoe, 
    atoe2          
    //所以这里默认暴露出去 atoe atoe2
}  

导入:

<script>
//这个allFn你想用什么名字都是可以的,just you like it. 
//注意点: 因为它导出来得是对象,所以不用花括号{},注意一下.
import allFn from '../js/atoeModule'
export default {
  methods: {
    runAtoe(params){
      allFn.atoe(params);
      allFn.atoe2(params);
    }
  },
}
</script>

<font size=4 color="###">总结:ES6模块化就这么点东西,但是这里导入导出太多方法了,请记住一点:用了一种就要一直用,不忘初心,懂吧,不然到后面你会怀疑你垃圾代码原来是自己写得.</font>

CommonJS(用于服务器)

node是用CommonJS规范的,然后node是后台语言,所以这个规范是用于服务器的.

导出:exports或者module.exports暴露需要被外部访问的属性和方法。<font size=4 color="red">记得别和ES6模块搞混了,export这是多个S, export default 也不一样.</font>

导入:require("url");

 var module = {
     exports: {}
 };

 (function (module, exports) {
     exports.atoe = function (n) { return n };
 }(module, module.exports))

 var atoe = module.exports.atoe;
 atoe(1) //1  这是CommonJS的原理

为什么CommonJS仅仅适用于服务器不适用浏览器?

场景:当我们需要加载一个模块的时候,这时候 CommonJS规范适用了 var atoe = require("atoe"); 如果在服务器完全ok的,因为atoe这个模块肯定在服务器,即拿即用.就是用的时候加载也ok,它就是运行的时候atoe才是确定的值,无所谓啊.然后当我们浏览器用的这个模块的时候还要去请求,好了拿到了,堵塞代码了,怎么可能会用这种规范.但是可以做其他处理,我觉得没有必要深究下去了.

import 是编译时就完成模块加载,效率比CommonJS,没有说CommonJS垃圾,只是说CommonJS只是用于服务器端.

AMD (Asynchronous Module Definition)用于浏览器

中文意思异步模块定义,有没有发现异步的东西好像都能扯上浏览器身上.

AMD 是RequireJS[模块加载器]的一种规范,然后加载的时候不会堵塞浏览器的渲染,AMD 推崇依赖前置

有趣的是webpack也是打包工具,但是它的规范是CommonJS

CMD(Common Module Definition )

CMD是Seajs [web端模块加载器]推广的产物,嗯,他对我未来的方向毫无帮助,我不打算去了解太深入,CMD 推崇依赖就近

我们的重点是ES6的模块化

模块化的发展史

历史故事总是有趣的

一、原始写法函数

function Atoe(){
    console.log("这是最low的模块写法")
}
其实当这个在现在偶尔还是会在页面出现的,因为简单易用的逻辑通过函数写出来,进行复用还是可取的,但是对于大的模块化是不可能的。
缺点:1.污染全局命名空间。
     2.容易引起命名冲突或数据不安全。
     3.而且模块成员之间看不出直接关系。

二、对象写法

let Atoe = {
    name : "Atoe",
    can : function(){
        console.log(`${this.name}can code`);
    }
}

解决问题:1.减少了全局变量。
         2.解决命名冲突。
缺点就是:1.对象外部可以修改内部的一切东西,不安全。

三、立即执行函数写法

 ((function (win) {
     let name = "Atoe";
     function atoe() {
         console.log("这是自调用函数里面的atoe函数");
     }

    win.me = { //win 接收到window参数,然后通过给windo添加一个me属性,将函数里面的东西暴露出去,见下图
        name:name,
        atoe:atoe
    }
 })(window))

console.log( window.me.name); //Atoe
window.me.atoe();             //这是自调用函数里面的atoe函数

// 大名鼎鼎的jQuery都是用立即执行函数,好像是一个天衣无缝的解决方案。
解决问题:外部无法修改里面的东西。

但是这个历史上面的,没有一个是真正严格意义上的模块化,真正的属于前端,而且适用于前端的,就是ES6模块

me加在window属性上.png

四.模块化。但是最后进化到ES6模块化。回到顶部在温故一下吧

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

推荐阅读更多精彩内容

  • Javascript模块化编程,已经成为一个迫切的需求。理想情况下,开发者只需要实现核心的业务逻辑,其他都可以加载...
    zhoulujun阅读 2,938评论 0 14
  • 官方中文版原文链接 感谢社区中各位的大力支持,译者再次奉上一点点福利:阿里云产品券,享受所有官网优惠,并抽取幸运大...
    HetfieldJoe阅读 3,657评论 2 27
  • 前面的话   JS用"共享一切"的方法加载代码,这是该语言中最易出错且容易令人感到困惑的地方。在ES6以前,在应用...
    CodeMT阅读 2,902评论 0 5
  • 时光越久就发现 能约出来的人越来越少 曾经同一条跑道的人走上分叉路口 彻夜聊天说心事的人 也没有再去打扰的借口 生...
    不忘初㣺阅读 327评论 1 0
  • 昨天,下班回到家23点。 收拾整理了一些闲置物品,准备拿来公司做激励,奖励给出单的伙伴们。于是东摸摸,西搞搞,一不...
    安然小语阅读 125评论 0 0