Koa項目使用ES6語法

上篇文章我們說到了使用Mongoose進(jìn)行增刪改查的操作,我們都知道ES6新增了很多的新特性巫员,那么我們?nèi)绻贙oa項目中使用ES6語法會如何呢庶香?

ES6, 全稱 ECMAScript 6.0 简识,是 JavaScript 的下一個版本標(biāo)準(zhǔn)赶掖,其中提供了很多的新語法新特性,但是很多情況下他是沒有辦法直接進(jìn)行使用的七扰,需要使用Babel來進(jìn)行轉(zhuǎn)換奢赂,那么我們的Koa項目是否能夠正常使用?

  • 首先我們在Koa項目中簡單的進(jìn)行測試一下颈走。
//首先我們安裝koa模塊
npm install koa
//然后在App.js里面進(jìn)行引入膳灶,通常我們使用都是
const Koa = require('koa')
  • 上面的這種寫法是我們ES5中所使用的,那么我們ES6使用的則是import的方法進(jìn)行引入立由,我們接下來試試看轧钓。
import Koa from 'koa'
  • 在引入完成后,我們運行項目測試一下看看
import Koa from 'koa'
       ^^^

SyntaxError: Unexpected identifier
    at Module._compile (internal/modules/cjs/loader.js:872:18)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:947:10)
    at Module.load (internal/modules/cjs/loader.js:790:32)
    at Function.Module._load (internal/modules/cjs/loader.js:703:12)
    at Function.Module.runMain (internal/modules/cjs/loader.js:999:10)
    at internal/main/run_main_module.js:17:11
npm ERR! code ELIFECYCLE
npm ERR! errno 1
npm ERR! koa-test@1.0.0 start: `node app.js`
npm ERR! Exit status 1
npm ERR!
npm ERR! Failed at the koa-test@1.0.0 start script.
npm ERR! This is probably not a problem with npm. There is likely additional logging output above.

npm ERR! A complete log of this run can be found in:
  • 很明顯锐膜,我們的項目報錯了毕箍。那么原因就是因為它無法識別我們import的語法,所以我們就需要使用到Babel轉(zhuǎn)換器來將ES6語法轉(zhuǎn)化為ES5語法道盏。
npm install @babel/core @babel/preset-env @babel/register @babel/cli @babel/node
  • 安裝完成后而柑,我們寫一個入口文件index.js然后將內(nèi)容與Babel引入在index.js中去。
require('@babel/register');
require('./src/app');
  • 接下來我們還需要一步則是需要在根目錄下創(chuàng)建.babelrc文件在文件內(nèi)進(jìn)行babel的配置
{
  "presets": ["@babel/preset-env"]
}
  • 官網(wǎng)描述說荷逞,babel就是下一代JavaScript 語法的編譯器媒咳。那么.babelrc文件就是Babel的配置文件。在進(jìn)行配置完成后种远,我們就可以嘗試運行了
//當(dāng)然 我簡單的在我的文件中console一下
console.log('GoodGoodGoGoGo')
console
  • 如我們所看涩澡,命令行不再報錯,并且正常進(jìn)行了運行院促。那么我們除了這個以外還是需要進(jìn)行打包拿到轉(zhuǎn)換后的代碼的筏养。那么我們就在package.json中進(jìn)行配置啟動項。
"build": "babel src --watch --out-dir dist"
  • 然后我們執(zhí)行npm run build嘗試


    命令行
  • 可以看到我們的命令行提示成功進(jìn)行了轉(zhuǎn)換常拓。并且在目錄中多出dist文件夾


    項目自動生成dist
  • 我們的Babel已經(jīng)自動幫我們完成了轉(zhuǎn)換渐溶,這樣我們就可以舒服的在Koa項目中使用ES6的語法啦。


    dist/app
完工~
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末弄抬,一起剝皮案震驚了整個濱河市茎辐,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌掂恕,老刑警劉巖拖陆,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異懊亡,居然都是意外死亡依啰,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進(jìn)店門店枣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來速警,“玉大人,你說我怎么就攤上這事鸯两∶凭桑” “怎么了?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵钧唐,是天一觀的道長忙灼。 經(jīng)常有香客問我,道長钝侠,這世上最難降的妖魔是什么该园? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮机错,結(jié)果婚禮上爬范,老公的妹妹穿的比我還像新娘。我一直安慰自己弱匪,他們只是感情好青瀑,可當(dāng)我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著萧诫,像睡著了一般斥难。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上帘饶,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天哑诊,我揣著相機與錄音,去河邊找鬼及刻。 笑死镀裤,一個胖子當(dāng)著我的面吹牛竞阐,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播暑劝,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼骆莹,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了担猛?” 一聲冷哼從身側(cè)響起幕垦,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎傅联,沒想到半個月后先改,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡蒸走,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年仇奶,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片比驻。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡猜嘱,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出嫁艇,到底是詐尸還是另有隱情朗伶,我是刑警寧澤,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布步咪,位于F島的核電站论皆,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏猾漫。R本人自食惡果不足惜点晴,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望悯周。 院中可真熱鬧粒督,春花似錦、人聲如沸禽翼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽闰挡。三九已至锐墙,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間长酗,已是汗流浹背溪北。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人之拨。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓茉继,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蚀乔。 傳聞我的和親對象是個殘疾皇子馒疹,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,627評論 2 350

推薦閱讀更多精彩內(nèi)容