自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用Babel和ES7創(chuàng)建JavaScript模塊

移動(dòng)開發(fā)
本文主要介紹通過 ES7 與 Babel 建立JavaScript 模塊,文章系國內(nèi)ITOM 管理平臺OneAPM 工程師編譯呈現(xiàn).

去年,新版的JavaScript發(fā)布了,它有很多新的優(yōu)點(diǎn)。其中之一就是導(dǎo)入導(dǎo)出模塊的語法被整理為JavaScript模塊處理的“唯一方法”。好吧,終于等到了。另一樁好事兒是,它的編排方式使你可以靜態(tài)分析整棵模塊依賴樹。真是相當(dāng)厲害。

讓我們來掃一眼這些語法:

  1. import v from "mod";  
  2. import * as obj from "mod";  
  3. import {x} from "mod";  
  4. import {x as v} from "mod";  
  5. import "mod";  
  6.  
  7. export var v;  
  8. export default function f(){};  
  9. export default function(){};  
  10. export default 42;  
  11. export {x};  
  12. export {x as v};  
  13. export {x} from "mod";  
  14. export {x as v} from "mod";  
  15. export * from "mod"

所以,基本上你可以導(dǎo)入一個(gè)模塊(“default”)的主要值,或者導(dǎo)入從顯式導(dǎo)出(explicit exports)而來的一個(gè)特定屬性,或者這二者的組合,或者是任何東西。相對應(yīng)的,你也可以為默認(rèn)模塊導(dǎo)出一個(gè)值,或者帶有多個(gè)屬性的對象。你也可以逐個(gè)導(dǎo)出這些屬性。***風(fēng)格還是請參考風(fēng)格指南吧;)

ES7中還加入了一些對這類語法的小補(bǔ)充。

  1. export * as ns from "mod";  
  2. export v from "mod"

沒啥特別的,但我們什么時(shí)候能使用它們呢?擇日不如撞日吧。就像對待很多ES6的語法特性,如果你目前不打算支持它們,可以用一種叫Babel的工具把它們轉(zhuǎn)譯回ES5。一旦你準(zhǔn)備支持它們了,就可以讓Babel停止轉(zhuǎn)譯。

讓我們來看一眼具體如何操作。我們將在Node.js與NPM中實(shí)現(xiàn)它。試試看執(zhí)行這個(gè)文件;

src/letter_keys.js

  1. // you would have a constant for each key  
  2. // (I would normally uppercase all constants)  
  3. const a = 119;  
  4. const d = 100;  
  5. const s = 115;  
  6. const w = 119;  
  7.  
  8. // you would export all keys here  
  9. // note: you can't say `w: 119` here. It just isn't valid.  
  10. // This destructures to `w: w, a: a, ...`  
  11. export {  
  12.   w,  
  13.   a,  
  14.   d,  
  15.   s,  

src/arrow_keys.js

  1. const UP = 38;  
  2. const RIGHT = 39;  
  3. const DOWN = 40;  
  4. const LEFT = 37;  
  5.  
  6. export {  
  7.   UP,  
  8.   RIGHT,  
  9.   DOWN,  
  10.   LEFT,  

 src/move.js

  1. export {a, w, s, d} from './letter_keys';  
  2. export * as ARROWS from './arrow_keys'

我們的設(shè)想是,index.js 主文件用于內(nèi)部模塊內(nèi)容的導(dǎo)出,它假設(shè)這些鍵是從其它文件中導(dǎo)出的。這個(gè)例子有點(diǎn)費(fèi)解,但是這并無大礙。

src/index.js

  1. import * as keys from './move';  
  2. console.log(keys); 

 這可以作為依賴這個(gè)模塊的某個(gè)項(xiàng)目的一部分。它應(yīng)當(dāng)打印awsd鍵以及箭頭對象。讓我們先從npm開始吧。創(chuàng)建repo dir并初始化:

  1. ~$ mkdir foo  
  2. ~$ cd foo  
  3. ~/foo$ mkdir src  
  4. # put src files above in ~/foo/src  
  5. ~/foo$ npm init -yes  
  6. ~/foo$ npm install babel-cli babel-preset-es2015 babel-preset-stage-1 -D 

  這得花點(diǎn)時(shí)間。你可能已經(jīng)猜到了, babel-cli 支持從命令行運(yùn)行Babel (6),并且, babel-preset-stage-1 包提供了相關(guān)的ES7模塊轉(zhuǎn)譯工具(在撰寫本文之時(shí))。 -yes 標(biāo)記會(huì)讓npm創(chuàng)建一個(gè)默認(rèn)的 package.json ,而不會(huì)詢問用戶。 -D 標(biāo)記是 --save-dev 的縮寫,它會(huì)在 package.json 中把包添加到 devDependency 條目下。現(xiàn)在,把預(yù)設(shè)參數(shù)添加入到默認(rèn)的babel配置文件中:

 .babelrc

  1. {  
  2.   "presets": ["es2015""stage-1"]  

 如果這能順利運(yùn)行,那就太好了,擁抱未來吧!但是,在筆者寫本文時(shí),這些示例在ES6中都無法運(yùn)行,更不用說Node.js了。經(jīng)過這些轉(zhuǎn)譯步驟,不管怎樣,它們可以被執(zhí)行了。

現(xiàn)在還應(yīng)該有一個(gè)幾乎為空的package.json文件,它包含了我們添加的那三個(gè)dev 依賴。讓我們給這個(gè)package.json 文件加一段腳本,來實(shí)現(xiàn)轉(zhuǎn)譯:

  1. ...  
  2.   "scripts": {  
  3.     "test""echo "Error: no test specified" && exit 1",  
  4.     "translate""node_modules/babel-cli/bin/babel-node.js src/index.js" 
  5.   },  
  6.   ... 

 (僅在“test”那行之后添加“translate”行及逗號)。

這段轉(zhuǎn)譯腳本是一個(gè)編譯步驟。在文章的結(jié)尾處,你可以找到本文(正式版本)使用的最終版package.json文件?,F(xiàn)在,只剩下調(diào)用npm指令來運(yùn)行腳本,以實(shí)現(xiàn)轉(zhuǎn)譯,并運(yùn)行我們的代碼了。

  1. ~/foo$ npm run translate --silent  
  2.  
  3. { A: [Getter],  
  4.   W: [Getter],  
  5.   S: [Getter],  
  6.   D: [Getter],  
  7.   ARROWS: { UP: 38, RIGHT: 39, DOWN: 40, LEFT: 37 } } 

加油!現(xiàn)在,作為額外獎(jiǎng)勵(lì),我們可以使用Jscrambler來“混淆”一下代碼。我們可以傳遞Babel轉(zhuǎn)譯后的代碼,所以干嘛不這么做呢?

我們(最終的)package.json文件是這樣的:

package.json

  1. {  
  2.   "name""foo",  
  3.   "version""1.0.0",  
  4.   "description""",  
  5.   "main""index.js",  
  6.   "scripts": {  
  7.     "test""echo "Error: no test specified" && exit 1",  
  8.     "translate""node_modules/babel-cli/bin/babel-node.js src/index.js" 
  9.   },  
  10.   "keywords": [],  
  11.   "author""Your Name <some@mail.local> (http://localhost/)",  
  12.   "license""ISC",  
  13.   "devDependencies": {  
  14.     "babel-cli""6.6.5",  
  15.     "babel-preset-es2015""6.6.0",  
  16.     "babel-preset-stage-1""6.5.0",  
  17.     "jscrambler""0.7.5" 
  18.   }  

 像往常一樣完成配置(如果使用的是Node.js,則需要一個(gè)專業(yè)版賬號)。以下是筆者所用的文件

.jscramblerrc

  1. {  
  2.   "keys": {  
  3.     "accessKey""See https://jscrambler.com/en/account/api_access",  
  4.     "secretKey""See https://jscrambler.com/en/account/api_access" 
  5.   },  
  6.   "params": {  
  7.     "constant_folding""%DEFAULT%",  
  8.     "dead_code""%DEFAULT%",  
  9.     "dead_code_elimination""%DEFAULT%",  
  10.     "dictionary_compression""%DEFAULT%",  
  11.     "dot_notation_elimination""%DEFAULT%",  
  12.     "function_outlining""%DEFAULT%",  
  13.     "function-reorder""%DEFAULT%",  
  14.     "literal_duplicates""%DEFAULT%",  
  15.     "literal_hooking""2;8",  
  16.     "member_enumeration""%DEFAULT%",  
  17.     "mode""nodejs",  
  18.     "rename_local""%DEFAULT%",  
  19.     "string_splitting":"0.3",  
  20.     "whitespace""%DEFAULT%" 
  21.   }  

我們用一段腳本來匯總一下。這段腳本將會(huì)用Babel翻譯源文件,輸出到/build文件夾,接著用Jscrambler混淆代碼,再將結(jié)果放入/dist文件夾。/dist里的內(nèi)容可以被正常運(yùn)行,而不必用到ES7的任何特性。

run.sh

  1. #!/bin/sh  
  2.  
  3. echo "Babelifying src/*.js" 
  4. node_modules/babel-cli/bin/babel.js -d build src/*.js  
  5. echo "Scrambling build/*.js" 
  6. node_modules/jscrambler/bin/jscrambler -o dist build/src/**  
  7. echo "Clean up artifacts" 
  8. mv dist/build/src/* dist/  
  9. rmdir dist/build/src  
  10. rmdir dist/build  
  11. echo "Done! See dist/scrambled.js" 
  12. echo "Running:" 
  13. node dist/index.js 

 使之準(zhǔn)備就緒:

 

  1. chmod +x run.sh 

接著,運(yùn)行:

 

  1. ~/foo$ ./run.sh   
  2. Babelifying src/*.js  
  3. src/arrow_keys.js -> build/src/arrow_keys.js  
  4. src/index.js -> build/src/index.js  
  5. src/letter_keys.js -> build/src/letter_keys.js  
  6. src/move.js -> build/src/move.js  
  7. Scrambling build/*.js  
  8. Clean up artifacts  
  9. Done! See dist/ for your scrambled files  
  10. Running:  
  11. { a: [Getter],  
  12.   w: [Getter],  
  13.   s: [Getter],  
  14.   d: [Getter],  
  15.   ARROWS: { UP: 38, RIGHT: 39, DOWN: 40, LEFT: 37 } } 

 你可以去/dist文件夾查看結(jié)果。你會(huì)看到,結(jié)果和原文件相去甚遠(yuǎn),這是因?yàn)槲覀兺ㄟ^Jscrambler來保護(hù)它,但是結(jié)果還是可以運(yùn)行的。

教程到此結(jié)束,祝ES7用得開心!

OneAPM 助您輕松鎖定Node.js 應(yīng)用性能瓶頸,通過強(qiáng)大的Trace 記錄逐層分析,直至鎖定行級問題代碼。以用戶角度展示系統(tǒng)響應(yīng)速度,以地域和瀏覽器維度統(tǒng)計(jì)用戶使用情況。

責(zé)任編輯:陳琳 來源: One APM官方博客
相關(guān)推薦

2016-10-19 19:03:18

javascriptes6React Nativ

2019-12-11 09:00:00

ES7ES8ES9

2020-07-09 08:01:48

JavaScriptES模塊

2021-06-28 08:10:59

JavaScript異步編程

2021-04-08 18:39:57

JavaScriptExpress區(qū)塊鏈

2009-04-23 13:19:21

創(chuàng)建XMLXML文件Javascript

2023-11-08 08:40:35

JavaScriptS 模塊

2020-10-17 09:03:06

使用JS創(chuàng)建復(fù)制&粘貼

2023-02-03 14:49:38

2021-01-19 06:16:05

前端Babel 技術(shù)熱點(diǎn)

2011-06-09 15:27:01

JavaScript

2020-12-23 14:18:43

JavaScript模塊導(dǎo)出

2023-05-11 08:00:00

JavaScript柱狀圖

2010-09-09 09:16:27

JavaScriptdiv

2020-11-18 09:06:02

JavaScript開發(fā)技術(shù)

2010-08-17 15:52:59

FirefoxIEJavaScript

2019-07-11 08:00:00

JavaScriptJulia編程語言

2023-03-01 15:39:50

JavaScrip對象屬性ES6

2023-05-28 23:49:38

JavaScrip開發(fā)

2021-06-10 18:40:32

ES 標(biāo)準(zhǔn)模塊化
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號