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

Node.js中ES6模塊化及Promise對象

 更新時間:2022年07月04日 09:00:41   作者:??vGuYi????  
這篇文章主要介紹了Node.js中ES6模塊化及Promise對象,node.js?遵循了?CommonJS?的模塊化規(guī)范,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下

ES6模塊化

CommonJS 規(guī)范

node.js 遵循了 CommonJS 的模塊化規(guī)范。其中:

  • 導(dǎo)入其它模塊使用 require()方法
  • 模塊對外共享成員使用 module.exports 對象

模塊化開發(fā)好處

模塊化開發(fā)的好處有很多,其中:

  • 實(shí)現(xiàn)了在JS文件中引用其他文件
  • 避免命名沖突的問題
  • 大家都遵守同樣的模塊化規(guī)范寫代碼,降低了溝通的成本,極大方便了各個模塊之間的相互調(diào)用
  • 只需關(guān)心當(dāng)前模塊本身的功能開發(fā),需要其他模塊的支持時,在模塊內(nèi)調(diào)用目標(biāo)模塊即可

模塊化規(guī)范劃分

在 ES6 模塊化規(guī)范誕生之前,JavaScript 社區(qū)已經(jīng)嘗試并提出了 AMD 、 CMD 、 CommonJS 等模塊化規(guī)范。 但是,這些由社區(qū)提出的模塊化標(biāo)準(zhǔn),還是存在一定的差異性與局限性、并不是瀏覽器與服務(wù)器通用的模塊化標(biāo)準(zhǔn)

  • AMD 和 CMD 適用于瀏覽器端的 Javascript 模塊化
  • CommonJS 適用于服務(wù)器端的 Javascript

模塊化太多的模塊化規(guī)范給開發(fā)者增加了學(xué)習(xí)的難度與開發(fā)的成本。因此,官方的 ES6 模塊化規(guī)范誕生了!

ES6模塊化開發(fā)注意點(diǎn)

node.js 中默認(rèn)僅支持 CommonJS 模塊化規(guī)范,若想基于 node.js 體驗(yàn)與學(xué)習(xí) ES6 的模塊化語法,需要按照如下兩個步驟進(jìn)行配置:

  • 確保安裝了 v13.0.0 或更高版本的 node.js
  • 在 package.json 的根節(jié)點(diǎn)中添加 "type": "module" 節(jié)點(diǎn)
  • 配置之后,則只能使用ES6模塊化語法,不能再使用CommonJS語法了

ES6 導(dǎo)入導(dǎo)出

主模塊:

// //導(dǎo)入子模塊
// //方法1.默認(rèn)導(dǎo)入  不能解構(gòu)接收
// import obj from './02-子模塊.js'
// console.log(obj);
// //不能再接收位置直接解構(gòu)
//import { fn, num } from './02-子模塊.js'
//方法2.按需導(dǎo)入
// import { str, fn2 } from './02-子模塊.js'
// console.log(str);
// fn2
//import bbb from './02-子模塊.js'
//方法3.只導(dǎo)入 不接收 使用的是功能
import './02-子模塊.js'
//es6也有緩存機(jī)制

子模塊:

//導(dǎo)出內(nèi)容
//方法1.默認(rèn)導(dǎo)出一次  不允許導(dǎo)出多次
// const num = 123
// function fn() {
//   console.log('我是函數(shù)fn');
// }
// export default { fn, num }

//方法2.按需導(dǎo)出  可以導(dǎo)出多次
//必須定義的時候就導(dǎo)出
// export const str = 'abc'
// export function fn2() {
//   console.log('我是函數(shù)fn2');
// }

//方法3.不導(dǎo)出任何數(shù)據(jù)  讓別人使用自己的功能
for (let i = 0; i < 3; i++) {
  console.log('重要的事情說三遍!');
}

Promise對象

異步操作是 JavaScript 編程的麻煩事,麻煩到一直有人提出各種各樣的方案,試圖解決這個問題。早期使用回調(diào)函數(shù)處理異步編碼,但存在回調(diào)地獄的問題。ES6中,新增了Promise 對象,從此異步編程擺脫了回調(diào)函數(shù)的束縛。

使用語法

let?p?=?new?Promise((resolve,?reject)?=>?{
 ? ?//?...?some?code
????if?(/*?異步操作成功?*/)?{
????????resolve(value);
????}?else?{
????????reject(error);
????}
});

注意點(diǎn):

  • new Promise()
  • 必須傳入一個函數(shù)作為Promise的參數(shù),這個函數(shù)在 new Promise的時候就會執(zhí)行
  • 函數(shù)有 resolve 和 reject 兩個形參
  • 函數(shù)就相當(dāng)于一個容器,可以將異步任務(wù)放到這里
  • 將異步任務(wù)成功的結(jié)果傳給 resolve 函數(shù);將失敗的信息傳給 reject 函數(shù)
p.then(
????result?=>?{?/*?獲取成功的結(jié)果?*/?}
);
// 或者
p.then(
????result?=>?{?/*?獲取成功的結(jié)果?*/?},
????err?=>?{?/*?獲取失敗的結(jié)果?*/?}
);
// 或者
p.then(
????result?=>?{?/*?獲取成功的結(jié)果?*/?}
).catch(
    err?=>?{?/*?獲取失敗的結(jié)果?*/?}
);

注意點(diǎn):

  • then方法接收以個函數(shù)類型的參數(shù),只處理成功
  • then方法接收兩個函數(shù)類型的參數(shù),分別用于接收 resolve 的值 和 reject 的值
  • then方法也可以只接收一個參數(shù),表示只接收 resolve 的值,失敗的結(jié)果可以通過鏈?zhǔn)秸{(diào)用catch方法捕獲

Promise中的同步異步

new Promise 和 new 其他對象一樣,是同步任務(wù)。

獲取結(jié)果時(調(diào)用 resolve 觸發(fā) then方法時)是異步的。

Promise 封裝

// 封裝
function?myReadFile(filename)?{
????return?new?Promise((resolve,?reject)?=>?{
????????fs.readFile(filename,?'utf-8',?(err,?data)?=>?{
????????????err???reject(err)?:?resolve(data.length);
????????})
????});
}
// 調(diào)用
myReadFile('./files/a.txt')
????.then(a?=>?{
????????console.log(a);
????????return?myReadFile('./files/b.txt');
????})
????.then(b?=>?{
????????console.log(b);
????????return?myReadFile('./files/c.txt');
????})
????.then(c?=>?{
????????console.log(c)
????})

第三方then-fs解決回調(diào)地獄

// npm  i  then-fs
const?fs?=?require('then-fs');
fs.readFile('./files/a.txt',?'utf-8')
????.then(res1?=>?{
????????console.log(res1);
????????return?fs.readFile('./files/b.txt',?'utf-8')
????})
????.then(res2?=>?{
????????console.log(res2);
????????return?fs.readFile('./files/b.txt',?'utf-8')
????})
????.then(res3?=>?{
????????console.log(res3)
????})

注意:未來很多模塊支持Promise對象開發(fā),就是返回的是一個Promise對象; 如 axios

到此這篇關(guān)于Node.js中ES6模塊化及Promise對象的文章就介紹到這了,更多相關(guān)Node.js ES6模塊 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • npm run dev和npm run serve的區(qū)別小結(jié)

    npm run dev和npm run serve的區(qū)別小結(jié)

    npm run serve和npm run dev是在開發(fā)階段使用npm運(yùn)行腳本的兩種常見命令,本文就來介紹一下這兩者的區(qū)別,具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • node.js遍歷目錄的方法示例

    node.js遍歷目錄的方法示例

    本篇文章主要介紹了node.js遍歷目錄的方法示例,主要介紹了同步遍歷和異步遍歷兩種方法,非常具有實(shí)用價值,需要的朋友可以參考下
    2018-08-08
  • 詳解Nodejs mongoose

    詳解Nodejs mongoose

    Mongoose 是在nodejs環(huán)境下,對mongodb進(jìn)行便捷操作的對象模型工具。本文介紹解(翻)密(譯)Mongoose插件。這篇文章給大家詳細(xì)介紹了Nodejs mongoose 的相關(guān)知識,感興趣的朋友一起看看吧
    2018-06-06
  • node.js中的fs.lchownSync方法使用說明

    node.js中的fs.lchownSync方法使用說明

    這篇文章主要介紹了node.js中的fs.lchownSync方法使用說明,本文介紹了fs.lchownSync的方法說明、語法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • Node.js中防止錯誤導(dǎo)致的進(jìn)程阻塞的方法

    Node.js中防止錯誤導(dǎo)致的進(jìn)程阻塞的方法

    這篇文章主要介紹了Node.js中防止錯誤導(dǎo)致的進(jìn)程阻塞的方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-08-08
  • nodejs連接ftp上傳下載實(shí)現(xiàn)方法詳解【附:踩坑記錄】

    nodejs連接ftp上傳下載實(shí)現(xiàn)方法詳解【附:踩坑記錄】

    這篇文章主要介紹了nodejs連接ftp上傳下載實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了node.js使用ftp模塊實(shí)現(xiàn)針對ftp上傳、下載相關(guān)操作的方法,并附帶記錄了傳輸速度慢的解決方法,需要的朋友可以參考下
    2023-04-04
  • Node.js之readline模塊的使用詳解

    Node.js之readline模塊的使用詳解

    這篇文章主要介紹了Node.js之readline模塊的使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • Node.js如何提取文件中的中文字符

    Node.js如何提取文件中的中文字符

    這篇文章主要介紹了Node.js如何提取文件中的中文字符,本文介紹了在Node.js開發(fā)中如何使用代碼提取文件中的中文字符,幫助開發(fā)者更好地處理中文文本數(shù)據(jù),提高開發(fā)效率
    2023-05-05
  • Nodejs?http模塊返回內(nèi)容中文亂碼問題及解決

    Nodejs?http模塊返回內(nèi)容中文亂碼問題及解決

    這篇文章主要介紹了Nodejs?http模塊返回內(nèi)容中文亂碼問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • node.js中的fs.symlink方法使用說明

    node.js中的fs.symlink方法使用說明

    這篇文章主要介紹了node.js中的fs.symlink方法使用說明,本文介紹了fs.symlink的方法說明、語法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12

最新評論