模塊化

一、為什么使用模塊化

不使用模塊化可能遇到的問題:全局變量同名的問題

A领虹,B在一個(gè)項(xiàng)目組中规哪,A創(chuàng)建了一個(gè)aaa.js文件,并且設(shè)置了一個(gè)var flag = true塌衰;之后诉稍,B創(chuàng)建了bbb.js文件定義了一個(gè)var flag = false;在這之后最疆,A因?yàn)樾枨缶Γ袆?chuàng)建了一個(gè)新的ccc.js文件,并且需要設(shè)置一個(gè)flag時(shí)肚菠,想起自己在aaa.js中設(shè)置了一個(gè)flag舔箭,所以就直接用了,并沒有設(shè)置新的;但是結(jié)果確實(shí)判斷為false层扶,A查看自己的代碼卻找不到問題所在箫章。這是因?yàn)榍岸舜a作用域的問題,ccc.js中判斷使用的是bbb.js中的flag镜会,所以是false檬寂。當(dāng)然,開發(fā)中一般很少遇到這種問題戳表,因?yàn)槎紩?huì)直接重新定義一個(gè)flag桶至。

全局變量同名的問題可以使用匿名函數(shù)(閉包)的方式解決,但是又會(huì)引出新的問題匾旭,那就是代碼的復(fù)用性變差了镣屹。因?yàn)楹瘮?shù)有自己的作用域,所以函數(shù)外無法使用函數(shù)內(nèi)定義的變量价涝,函數(shù)女蜈。這時(shí)就出現(xiàn)了模塊化的雛形來解決這個(gè)問題。

二色瘩、什么是模塊化

綜上伪窖,我們?yōu)榱私鉀Q全局變量重名的問題,使用匿名函數(shù)居兆,從而引發(fā)新的問題覆山,代碼復(fù)用性變差。為了解決這一問題泥栖,模塊化的被提出:在匿名函數(shù)內(nèi)部定義一個(gè)對(duì)對(duì)象簇宽,將各種需要暴露出到外面的屬性和方法添加到對(duì)象中,最后將這個(gè)對(duì)象返回聊倔,使用一個(gè)模塊接受這個(gè)對(duì)象。這就是模塊化生巡。

如下代碼耙蔑,在匿名函數(shù)中返回一個(gè)obj,其中放入我們需要的值孤荣,就可以使用函數(shù)內(nèi)的變量或者函數(shù)了甸陌。這樣就解決了代碼復(fù)用性的問題

aaa.js文件中這樣寫
var moduleA = (function () {
  var obj = {};
  var name = '小明';
  var age = 26;
  function sum(num1,num2) {
    return num1 + num2
  };
 var flag = true;
  if (flag){
    console.log(sum(10, 40));
  }

  obj.flag = flag;
  obj.sum = sum;

  return obj;
})();
bbb.js中,可以通過(模塊名.屬性名)的方式獲取需要的值或者函數(shù)
(function () {
  if(moduleA.flag) {
    console.log('小明是天才');
  }
  console.log(moduleA.sum(11, 24));
})();

上述就是模塊化最基礎(chǔ)的封裝盐股,模塊的原始雛形钱豁。
現(xiàn)在前端模塊化開發(fā)已經(jīng)有了很多既有的規(guī)范,以及對(duì)應(yīng)的實(shí)現(xiàn)方案疯汁。

常見的模塊化規(guī)范
  • CommonJS(Node)
  • AMD
  • CMD
  • ES6的Modules

三牲尺、CommonJS(了解)

模塊化有兩個(gè)核心:導(dǎo)出和導(dǎo)入
CommonJS的導(dǎo)出:
module.exports = {
  flag: flag,
  sum: sum
}
CommonJS的導(dǎo)入:
var {flag,sum} = require('.../aaa.js')
上面是增強(qiáng)寫法,等同于
var aaa = require('.../aaa.js')
var flag = aaa.flag;
var sum = aaa.sum;

四、ES模塊化的導(dǎo)入(import)和導(dǎo)出(export)(掌握)

ES6中將一個(gè)js文件設(shè)置為一個(gè)模塊:type="module"

<script src="aaa.js" type="module"></script>
<script src="bbb.js" type="module"></script>
<script src="mmm.js" type="module"></script>

這樣每個(gè)js文件就是一個(gè)模塊谤碳,互相不干擾溃卡,不會(huì)出現(xiàn)命名重復(fù)問題,但如果一個(gè)模塊需要使用另一個(gè)模塊的數(shù)據(jù)蜒简,就需要導(dǎo)出導(dǎo)入了瘸羡。

export導(dǎo)出的幾種方式

let name = '小明';
let age = 25;
let flag = true;
function sum(num1, num2) {
  return num1 + num2
}
if (flag){
  console.log(sum(10, 20));
}

//1.第一種導(dǎo)出方式
export {
  flag, sum
}

//2.第二種導(dǎo)出方式
export var num1 = 10000;
export var height = 1.88;

//3.導(dǎo)出function/class
export function mul(num1, num2) {
  return num1 * num2
}

export class Person{
  run() {
    console.log('在奔跑');
  }
}

//4.export default  注意:在一個(gè)模塊中default只能有一個(gè)

const address = '北京';
export default address;

// export default function (string) {
//   console.log(string);
// }

import導(dǎo)入的幾種方式

//1.導(dǎo)入{}中的數(shù)據(jù)
import {flag, sum} from "./aaa.js";
if(flag) {
  console.log('小明是天才');
}

//2.對(duì)應(yīng)第二種導(dǎo)出方式
import {num1, height} from "./aaa.js";
console.log(num1);
console.log(height);

//3.導(dǎo)入function/class
import {mul, Person} from "./aaa.js";
console.log(mul(10, 20));

var a = new Person();
a.run();

//4.導(dǎo)入default
import myFuc from "./aaa.js";
console.log(myFuc);
// myFuc('默認(rèn)事件');


//5.全部導(dǎo)入
import * as aaa from "./aaa.js";
console.log(aaa.flag);
console.log(aaa.mul(11, 20));
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市搓茬,隨后出現(xiàn)的幾起案子犹赖,更是在濱河造成了極大的恐慌,老刑警劉巖卷仑,帶你破解...
    沈念sama閱讀 212,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件峻村,死亡現(xiàn)場離奇詭異,居然都是意外死亡系枪,警方通過查閱死者的電腦和手機(jī)雀哨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來私爷,“玉大人雾棺,你說我怎么就攤上這事〕幕耄” “怎么了捌浩?”我有些...
    開封第一講書人閱讀 158,369評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長工秩。 經(jīng)常有香客問我尸饺,道長,這世上最難降的妖魔是什么助币? 我笑而不...
    開封第一講書人閱讀 56,799評(píng)論 1 285
  • 正文 為了忘掉前任浪听,我火速辦了婚禮,結(jié)果婚禮上眉菱,老公的妹妹穿的比我還像新娘迹栓。我一直安慰自己,他們只是感情好俭缓,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,910評(píng)論 6 386
  • 文/花漫 我一把揭開白布克伊。 她就那樣靜靜地躺著,像睡著了一般华坦。 火紅的嫁衣襯著肌膚如雪愿吹。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,096評(píng)論 1 291
  • 那天惜姐,我揣著相機(jī)與錄音犁跪,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛耘拇,可吹牛的內(nèi)容都是我干的撵颊。 我是一名探鬼主播,決...
    沈念sama閱讀 39,159評(píng)論 3 411
  • 文/蒼蘭香墨 我猛地睜開眼惫叛,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼倡勇!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起嘉涌,我...
    開封第一講書人閱讀 37,917評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤鸯檬,失蹤者是張志新(化名)和其女友劉穎饮六,沒想到半個(gè)月后踊沸,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體肄鸽,經(jīng)...
    沈念sama閱讀 44,360評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,673評(píng)論 2 327
  • 正文 我和宋清朗相戀三年警医,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了亿胸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,814評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡预皇,死狀恐怖侈玄,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情吟温,我是刑警寧澤序仙,帶...
    沈念sama閱讀 34,509評(píng)論 4 334
  • 正文 年R本政府宣布,位于F島的核電站鲁豪,受9級(jí)特大地震影響潘悼,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜爬橡,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,156評(píng)論 3 317
  • 文/蒙蒙 一治唤、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧糙申,春花似錦宾添、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽掷漱。三九已至粘室,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間卜范,已是汗流浹背衔统。 一陣腳步聲響...
    開封第一講書人閱讀 32,123評(píng)論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人锦爵。 一個(gè)月前我還...
    沈念sama閱讀 46,641評(píng)論 2 362
  • 正文 我出身青樓舱殿,卻偏偏與公主長得像,于是被迫代替她去往敵國和親险掀。 傳聞我的和親對(duì)象是個(gè)殘疾皇子沪袭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,728評(píng)論 2 351