欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解JS模塊導(dǎo)入導(dǎo)出

 更新時(shí)間:2017年12月20日 08:29:57   投稿:laozhang  
這篇文章主要介紹了詳解JS模塊導(dǎo)入導(dǎo)出以及相關(guān)問題解決方法,需要的朋友學(xué)習(xí)參考下吧。

開發(fā)中基本不會(huì)將所有的業(yè)務(wù)邏輯代碼放在一個(gè)JS文件中,特別是在使用前端框架,進(jìn)行組件化開發(fā)中時(shí),會(huì)復(fù)用相應(yīng)的組件。這時(shí),就會(huì)用到模塊導(dǎo)入/導(dǎo)出的方法了。

當(dāng)然,上面提到有模塊的概念,也是在JS用于服務(wù)器端編程的時(shí)候才會(huì)出現(xiàn),我們在使用前端框架時(shí),使用npm run dev,不就是啟動(dòng)了一個(gè)node服務(wù)。 對于JavaScript模塊化編程的起源可以追溯到2009年,Ryan Dahl在github上發(fā)布了node 的最初版本。

本文主要介紹幾種模塊導(dǎo)入/導(dǎo)出的方法。

node 中模塊導(dǎo)出/導(dǎo)入

平時(shí)我們接觸最多的模塊導(dǎo)入的例子,就是使用npm安裝各種開源模塊,然后在項(xiàng)目中使用例如import,require的方法引入,或者更加直白的直接使用script標(biāo)簽引入入node_module中對應(yīng)模塊打包過后的源文件。

為什么可以直接引入這些npm模塊呢?一般在每個(gè)模塊的源文件里面,都會(huì)找到modules.exports方法。用來導(dǎo)出變量。比如下面我們在使用gulp打包壓縮時(shí),經(jīng)常使用到的gulp-rename這個(gè)插件通過npm安裝后,在node_modules中的gulp-rename/index.js

'use strict';

var Stream = require('stream');
var Path = require('path');

function gulpRename(obj) {

 var stream = new Stream.Transform({objectMode: true});
 ... 

 return stream;
}

module.exports = gulpRename;

看到的基本思路就是,定義了gulpRename 方法,然后把它拋出去。

node中的module都遵循CommonJS規(guī)范。在CommonJS中有一個(gè)全局的require()方法,用于加載模塊;module.export 和 export 方法,導(dǎo)出模塊。

這里比較重要的一點(diǎn)是: 我們在寫模塊時(shí)用到的exports對象實(shí)際上只是對module.exports的引用,所有在一些js庫的源碼中,經(jīng)常可以看到這樣的寫法:

exports = module.exports = somethings

 // export.js 文件中
var export1 = "from export1"
var export2 = function(){
 return "from export2";
}
exports.export2 = export2;
 // modules.js 文件中
 var module1 = "from module1";
 var module2 = function(e){
 return "from funModule2";
 }
 module.exports.str1 = module1;
 module.exports.fun2 = module2;

最后在common.js文件中引入exports.js文件和 modules.js 文件,

var md1 = require("./module.js")
console.log(md1);
var export3 = require("./export");
console.log(export3);

最后在gitbash中,使用node 執(zhí)行相應(yīng)的commons.js文件;

在使用exports方法是,不能直接exprots = {},這樣改變了exports方法的引用, 相應(yīng)就無法實(shí)現(xiàn)導(dǎo)出模塊的功能了。

es6導(dǎo)出方法

es6中也同樣提出了比較好用的模塊導(dǎo)出的方法,包括兩種。

命名導(dǎo)出

如果在一個(gè)文件中想要導(dǎo)出多個(gè)不同的變量,可以分別對不同的變量命名,然后分別導(dǎo)出,避免相互污染。

// export3.js 文件
 export const myModules = {c:1 }
 export const myModules2 = {d:2 }
 // import.js 文件
 import {myModule1,myModule2} from './export3.js' ;
 console.log(myModule1);
 console.log(myModule2);
 // index.html 文件
<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8">
 <title>es6</title>
 </head>
 <body>
 <script src="./import.js"></script>
 </body>
</html>

然后,我們嘗試使用最經(jīng)新出的 打包工具parcel(node版本在8.0以下安裝會(huì)報(bào)錯(cuò))小試牛刀, 具體已經(jīng)安裝完成了,在命令行中輸入 parcel index.html,就會(huì)在1234 端口啟動(dòng)服務(wù),主要為了能夠在http://localhost:1234/中看到console。

默認(rèn)導(dǎo)出

如果只在一個(gè)文件中提供了一個(gè)導(dǎo)出的口,就可以使用默認(rèn)導(dǎo)出

//export4.js 
 const str2 ="hello world";
 export default str2 ;
 // import2.js
 import anyName from "./export4.js"
 console.log(anyName);

在index.html 中 <script src="./import2.js"></script>可以看到輸入 hello world

同樣是模塊導(dǎo)入導(dǎo)出方法,使用es6的模塊方法,要比node中 的(也就是CommonJS模塊)方法更加的差異非常大。
主要有如下兩點(diǎn)差別:

CommonJS 模塊輸出的是一個(gè)值的拷貝,ES6 模塊輸出的是值的引用。

CommonJS 模塊是運(yùn)行時(shí)加載,ES6 模塊是編譯時(shí)輸出接口。

以上就是我們本次給大家介紹的關(guān)于JS模塊導(dǎo)入導(dǎo)出問題的全部內(nèi)容,如果大家還有任何不明白的地方可以在下方的留言區(qū)域討論,感謝你對腳本之家的支持。

相關(guān)文章

最新評論