精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

JSDev:一個優化JavaScript開發過程的小工具

開發 前端
JSDev 是老道(Douglas Crockford)最近搞的一個不太起眼的小玩意,他的大致思路是,對 JavaScript 做預處理,選擇性地把注釋轉為相應的代碼。

JSDev 是老道(Douglas Crockford)最近搞的一個不太起眼的小玩意,他的大致思路是,對 JavaScript 做預處理,選擇性地把注釋轉為相應的代碼。JSDev 處理的注釋塊有以下兩種形式:

  1. /*<tag> <stuff>*/ 
  2. /*<tag>(<condition>) <stuff>*/ 

然后你可以指定 JSDev 開啟哪些 tag,JSDev 就會把這塊注釋改成相應的代碼,而這些注釋在 JavaScript 正常運行的時候是不會起作用的,在用 JSMin 等工具壓縮后也都會全被去掉,這樣就方便了 JavaScript 的開發。

一開始,老道只給出了 C 語言版本的程序,幾天后他給出了 JavaScript 版本,我覺得這開始變得有意思了,折騰了兩天,想試看能否用到今后的開發項目中去。下面我們先以 C 程序為例說明 JSDev 的用法,然后說說怎樣通過 JavaScript 版本把它用在 node 開發或者前端開發過程中。本文假定你在類 Unix 系統(Linux/FreeBSD/Mac OS)下工作并且對命令行、node 編程都有一定了解。

C 語言版本 和 JSDev 的用法

先從 github 上 clone 我的 fork,把 C 源碼編譯成可執行文件。

  1. git clone https://github.com/yuest/jsdev.git #clone github 上的源代碼到本地  
  2. cd jsdev  
  3. gcc jsdev.c #編譯 C 版本  
  4. sudo mv a.out /usr/local/bin/jsdev #把編譯好的可執行文件移動到一個 $PATH 底下的目錄 

現在我們就可以用 jsdev 來運行程序了??墒窃诿钚休斎?jsdev 并回車,卻什么都沒有,原來老道只做了這工具最核心的部分,而未在軟件界面下什么功夫,所以連個命令用法提示也沒有。作為預處理器,它只會從 stdin 吃進 JavaScript 代碼,然后把處理過的代碼從 stdout 拉出來,至于文件操作嘛,用 unix 命令行的管道特性就可以啦。

普及一下,要把文件,比如說 in.js 當 stdin 輸入到 jsdev 程序,使用小于符號 < 就行,如 jsdev <in.js,而輸出就是用大于符號 > 啦:jsdev <in.js >out.js 就可以。如果要嘗試 jsdev,只需要用 jsdev <in.js 就可以把結果輸出到屏幕上方便查看,或者你甚至可以配合使用 echo 命令來測試簡單的單行代碼。如 echo "/*tag 'stuff'*/" |jsdev tag

只運行 jsdev <in.js >out.js 這個命令不會對 in.js 有任何改動,我們需要以 tag 為參數調用 jsdev 命令來指定需要開啟的 tag,多個空格間用空格分開。以例子來說明,如果 in.js 代碼如下:

  1. /*hello console.log('Hello, World!')*/ 
  2. /*hi console.log('Hi, there.')*/ 

那么 jsdev <in.js hello 會輸出如下代碼:

  1. {console.log('Hello, World!')}  
  2. /*hi console.log('Hi, there.')*/ 

而 jsdev <in.js hello hi 則是:

  1. {console.log('Hello, World!')}  
  2. {console.log('Hi, there.')} 

這里的花括號是為了避免與程序中其他部分發生關聯而加的,主要問題是 JavaScript 有行尾自動插入分號的設計,如果不加花括號把上下文隔開,可能會與前后行產生關聯,比如變成上一行的函數調用之類?;ɡㄌ枌嶋H上是把多個語句復合成一個語句,最常見的地方是用在 if 等僅接受一個語句的關鍵字后。JavaScript 里面的花括號不會產生一個命名空間。

你可以為 tag 指定一個函數名,于是此 tag 指定的注釋塊就會被這個函數名 wrap(有點像 JSONP),如以下 in.js:

  1. /*log some_variable*/ 

用命令 jsdev <in.js log:console.log 輸出的是:

  1. {console.log(some_variable);} 

這可以用于調試代碼時打印當時狀態下的某些變量值,會比較方便。

另外還可以為注釋塊指定條件,如下的 in.js:

  1. var name = 'Yuest' 
  2. /*hello console.log('Hello, World!')*/ 
  3. /*hello(name === 'Celine') console.log('Hello, Celine!')*/ 

用命令 jsdev <in.js hello 輸出:

  1. var name = 'Yuest' 
  2. {console.log('Hello, World!')}  
  3. if (name === 'Celine') {console.log('Hello, Celine!')} 

如果運行這段代碼,很顯然只會輸出 Hello, World!。

指定函數和條件也可以同時使用,如:

  1. var name = 'Yuest' 
  2. /*log 'Hello, World!'*/ 
  3. /*log(name === 'Ling') 'Hello, Ling!'*/ 

用命令 jsdev <in.js log:console.log 輸出:

  1. var name = 'Yuest' 
  2. {console.log('Hello, World!');}  
  3. if (name === 'Ling') {console.log('Hello, Ling!');} 

和前面幾乎是一樣的,但注釋短了不少。以上就是關于 JSDev 使用方法的一切了。其實最核心的是 /*<tag> <stuff>*/ 這種形式,我們可以完全只用這種形式來達到上面一樣的目的:

  1. var name = 'Yuest' 
  2. /*hello console.log('Hello, World!')*/ 
  3. /*hello if (name === 'Ling') {console.log('Hello, Ling!')}*/ 

上面的代碼用命令 jsdev <in.js hello 輸出:

  1. var name = 'Yuest' 
  2. {console.log('Hello, World!')}  
  3. {if (name === 'Ling') {console.log('Hello, Ling!')}} 

所以可以看出,為 tag 指定函數名和條件只是做了一些簡化而已。

哦對了,還忘了 jsdev 命令接受一個 -comment 參數為輸出的文件頭部添加注釋,如對于上面的 in.js 文件,運行一下命令:

  1. jsdev <in.js hello -comment "Author: Yuest" -comment "This is a temporary file generated by JSDev" 

會獲得:

  1. // Author: Yuest  
  2. // This is a temporary file generated by JSDev  
  3. var name = 'Yuest' 
  4. {console.log('Hello, World!')}  
  5. {if (name === 'Ling') {console.log('Hello, Ling!')}} 

嗯,以上就真的是關于 JSDev 用法的一切了,而關于要如何用好它,則需要他的使用者有一點想象力。比如,你可以寫一些 bash 腳本什么的。下面說說 JavaScript 版本的 JSDev 以及我想到的用在 node 項目的方法。

JavaScript 版本和 node 中用法

老道給出的 jsdev.js 里面只定義了一個 JSDEV 函數,接受三個參數,***個參數是要處理的源代碼,第二、三個參數是兩個數組,分別指定 tag 和注釋。如果上面***一條命令用 JavaScript 版本來處理,就應該是:

  1. JSDEV( input  
  2.      , ['hello']  
  3.      , ['Author: Yuest''This is a temporary file generated by JSDev']) 

我的 fork 為 node 加上了 exports.JSDEV = JSDEV,并 publish 到 npm 上了,你只需 npm install jsdev 或者在 package.json 里面加上 jsdev 的依賴,并在源碼里

  1. var JSDEV = require('jsdev').JSDEV 

就可以使用 JavaScript 版本的 JSDEV() 函數了。

因為 node 可以通過修改 module.constructor.prototype._compile 來修改要載入的文件,非常適合拿來應用 JSDev 這種預處理器。我的想法是,一個文件要開啟哪些 tag 下的注釋塊,應該在其自身(也是用注釋)來描述。如果程序載入了 jsdev 并調用其 replaceRequire 方法(require('jsdev').replaceRequire()),之后再 require 進的文件有 //@jsdev tag1 tag2 這樣的注釋,就會用 jsdev 開啟 tag1、tag2 指定的注釋塊。

指定開啟 tags 的規則這樣寫:

  1. //@jsdev(test,production) tag1 tag2  
  2. //@jsdev(development) tag3 

以上注釋行表示在環境變量 NODE_ENV=test 或 NODE_ENV=production 的時候開啟本文件的 tag1 tag2 注釋塊,在 NODE_ENV=development 時開啟 tag3 注釋塊。如果沒有 jsdev 后面的括號,默認是 development,因此可以寫成

  1. //@jsdev(test,production) tag1 tag2  
  2. //@jsdev tag3 

例如有 a.js:

  1. require('jsdev').replaceRequire()  
  2. require('./b'

b.js:

  1. //@jsdev(test,production) hello  
  2. //@jsdev hi  
  3. /*hello console.log('hello')*/ 
  4. /*hi console.log('hi')*/ 

則運行 node a.js 會輸出 hi,而運行NODE_ENV=test 則會輸出 hello

另外,對于前端開發也是一樣的,有 replaceStatic() 函數,可以替換 connect/express 的 static middleware。這樣就可以預處理通過 static middleware 返回到瀏覽器的 js 文件。文件內 tag 開啟的規則和前面寫的一樣。需要注意的是要在使用 connect.static(root) 之前調用 replaceStatic()。

更多的例子可以參考我寫的測試,在遷出的代碼中 ./runtests (當然要確保 npm 依賴已經安裝,即在目錄下運行 npm install)就可以運行測試。我在這里提供這個很通用的工具的用法,要怎樣用好它(什么環境設定什么 tag 之類),就要靠用戶的想象力了吧。

有不足的地方歡迎指證,可以到 github 里面去提 issue。

原文:http://club.cnodejs.org/topic/4f3b65a1b43c3c846a05518c

【編輯推薦】

  1. JavaScript MVC框架backbone.js初探
  2. JavaScript繼承詳解
  3. 8個***的JavaScript腳本資源強烈推薦
  4. 10個強大的JavaScript表單驗證插件
  5. 20個將JavaScript推到***的網站
責任編輯:陳貽新 來源: CNode
相關推薦

2022-12-28 12:29:45

duf命令

2017-07-25 14:20:13

戴爾配置功耗

2011-05-03 10:17:25

CSS

2013-03-29 14:46:33

App開發小工具輔助工具

2022-03-30 15:11:26

Python房價工具

2021-05-10 11:06:31

Python工具代碼

2020-11-26 12:05:44

Python小工具代碼

2021-05-20 11:30:17

Python工具代碼

2019-12-03 10:19:34

開發者技能工具

2023-04-26 01:21:34

工具URL地址

2021-11-02 15:07:22

Web前端開發

2017-05-23 20:44:36

Linux緩存工具

2019-07-11 15:24:30

開發者技能工具

2020-08-25 20:10:53

GitHub代碼開發者

2022-05-17 16:56:33

開發工具前端

2009-11-19 08:48:10

Windows 7桌面工具

2010-06-02 10:00:25

MySQL工具

2024-09-24 17:54:26

Python開發

2021-11-05 06:57:50

架構工具代碼

2015-03-26 10:34:02

Android開發工具
點贊
收藏

51CTO技術棧公眾號

99久久综合狠狠综合久久止 | 色噜噜狠狠色综合网图区| 黄色片久久久久| 欧美三级黄网| gogo大胆日本视频一区| 国产成人精品一区| 三上悠亚在线观看视频| 精品国产午夜肉伦伦影院| 91精品91久久久中77777| av动漫免费观看| 三级视频网站在线| 国产精品99久久久久久久女警| 欧美激情亚洲自拍| 中文天堂资源在线| 日本久久成人网| 91精品国产综合久久久蜜臀图片 | 精品众筹模特私拍视频| 久久久久久久久久久久久夜| 亚洲一区二区三区sesese| 国产精品一区二区三区四| 91日韩在线| 亚洲美女性视频| 在线成人精品视频| 欧美日韩卡一| 日本高清不卡视频| 水蜜桃色314在线观看| 超碰免费公开在线| 国产精品网曝门| 农村寡妇一区二区三区| 亚洲精品久久久蜜桃动漫| 久久国产麻豆精品| 国产精品91久久久| 亚洲欧美综合另类| 激情91久久| 久久精品亚洲94久久精品| 中文字幕人妻一区二区三区在线视频| 韩国女主播一区二区三区| 91精品国产综合久久精品图片| 天天操天天爽天天射| 香蕉久久免费电影| 狠狠操狠狠色综合网| 色欲色香天天天综合网www| av网站网址在线观看| 中文字幕一区二区日韩精品绯色| 日本一区二区精品| 巨骚激情综合| 久久久国产精品麻豆| 久久伦理网站| 午夜视频免费看| 99久久免费精品| 国产伦精品一区二区三区照片| 成人黄色在线观看视频| 国产精品综合网| 亚洲综合自拍一区| 亚洲黄色一级大片| 成人黄色av网站在线| 国产精品免费一区二区三区| 成人免费公开视频| av福利精品导航| 精品国产乱码久久久久软件| 亚洲欧洲综合在线| 久久亚洲综合色| 日韩欧美视频一区二区| av女优在线| 自拍偷拍亚洲激情| 精品国产一区二区三区在线| 91精选在线| 亚洲国产日韩一区二区| 成人黄色av片| 成人免费影院| 欧美日韩黄色一区二区| 手机在线免费毛片| 国内精品麻豆美女在线播放视频| 精品亚洲国产成av人片传媒| av电影网站在线观看| 全球成人免费直播| 欧美大胆a视频| 亚洲综合一二三| 久久伊人亚洲| 成人精品在线视频| 全国男人的天堂网| 国产日韩成人精品| 法国空姐在线观看免费| 色一区二区三区| 欧美色视频在线观看| 国产精品91av| 国产成人ay| 免费av一区二区| 亚洲黄色三级视频| 美国一区二区三区在线播放| 7777精品伊久久久大香线蕉语言| 婷婷视频在线观看| 国产视频一区二区在线| 大地资源网在线观看免费官网| 日产福利视频在线观看| 欧美丰满一区二区免费视频| 一级黄色片毛片| 日韩在线观看| 2021国产精品视频| 国产色综合视频| 久久午夜电影网| 欧美日韩视频免费| 久久av日韩| 日韩电影大全免费观看2023年上 | 亚洲a一区二区三区| 57pao精品| 国产按摩一区二区三区| 久久精品免费在线观看| 国产美女主播在线| 久久天天久久| 亚洲视频在线观看| 日本少妇激情舌吻| 国产一区二区h| 视频一区不卡| 午夜影院在线播放| 精品国产一二三| 国内毛片毛片毛片毛片毛片| 亚洲制服av| 国产日韩一区二区| а√天堂官网中文在线| 欧美视频第二页| aaaaa级少妇高潮大片免费看| 欧美韩国一区| 成人在线国产精品| 91精品专区| 在线观看三级视频欧美| 精品人妻一区二区三区香蕉| 黄色成人精品网站| 91成人免费看| 国产黄色在线网站| 欧美精品xxxxbbbb| 日本视频在线免费| 免费高清不卡av| 亚洲激情图片| 欧美影视资讯| 国产一区二区免费| 精品黑人一区二区三区| 久久综合色8888| 黄色av网址在线播放| 欧美wwwwww| 午夜精品久久久久久久白皮肤 | 成人综合在线网站| 日本高清视频免费在线观看| 国产福利一区二区三区在线播放| 国产性色av一区二区| 国产精品一区无码| 国产性天天综合网| 99视频免费播放| 成人高清电影网站| 成人a视频在线观看| 麻豆传媒在线完整视频| 欧美一区二区三区在线| 欧美性猛交xxxxx少妇| 国产福利精品一区二区| 91成人综合网| 欧美一级一片| 日韩av快播网址| wwwxxx在线观看| 欧美人妇做爰xxxⅹ性高电影| jizzjizz日本少妇| 国产精品一二三四区| 六月婷婷激情综合| 欧美一区二区三区红桃小说| 日韩av免费在线播放| 国产午夜在线视频| 欧美二区在线观看| 欧美色图亚洲天堂| 91久色porny| 在线观看的毛片| 影音先锋日韩精品| 岛国一区二区三区高清视频| 蜜桃麻豆影像在线观看| 一本色道久久综合狠狠躁篇的优点| 国产精品自拍第一页| 亚洲女人的天堂| av在线播放网址| 日本免费新一区视频| 日本高清视频免费在线观看| 欧美在线导航| 成人欧美一区二区三区在线湿哒哒 | 国产午夜精品一区在线观看| 久久理论片午夜琪琪电影网| 黄色av免费在线观看| 欧美日韩第一区日日骚| 久久精品无码人妻| 中文字幕免费在线观看视频一区| 无套内谢丰满少妇中文字幕| 国产亚洲激情| 亚洲一二三区在线| 精品淫伦v久久水蜜桃| 国产精品自在线| 爱啪啪综合导航| 日韩视频―中文字幕| 欧美在线 | 亚洲| 欧美日韩成人在线| 国产精品一区二区三区四| 亚洲视频在线一区二区| 午夜理伦三级做爰电影| 国产传媒一区在线| 国产免费999| 亚洲经典自拍| 欧美一级黄色录像片| 蜜桃一区二区三区| 国产精品久久久一区二区三区| 深夜视频一区二区| 97精品一区二区三区| 韩国中文字幕在线| 亚洲桃花岛网站| 手机在线观看免费av| 欧美一区二区三区四区在线观看| 久操视频在线免费观看| 亚洲图片欧美视频| 1024手机在线视频| 综合色天天鬼久久鬼色| www.黄色在线| 91丨九色porny丨蝌蚪| 亚洲欧美高清在线| 国产老肥熟一区二区三区| 蜜臀视频一区二区三区| 亚洲综合精品| 日本丰满少妇xxxx| 欧美黄免费看| 欧美人与动牲交xxxxbbbb| 久久一区91| 亚洲国产精品综合| 精品久久久亚洲| 国产在线一区二区三区播放| 99这里只有精品视频| 91黄色精品| 久久久久亚洲精品中文字幕| 成人激情视频网| 亚洲tv在线| 国产欧美一区二区三区在线| 福利一区二区三区视频在线观看| 国产va免费精品高清在线观看 | 亚洲精品二区三区| 香蕉精品视频在线| 国产精品国产一区| 一区在线电影| 综合天堂av久久久久久久| 中文字幕免费高| 一本一道久久a久久精品蜜桃| 在线观看精品视频| 91精品国产调教在线观看| 亚洲一区综合| 亚洲精品电影| 国产精品视频网站在线观看| 亚洲网站在线| 2018日日夜夜| 翔田千里一区二区| 女人另类性混交zo| 美女视频网站久久| 国产无遮挡猛进猛出免费软件 | 99精品国产在热久久| 免费无码不卡视频在线观看| 在线亚洲伦理| 国产v亚洲v天堂无码久久久| 免费在线视频一区| 亚洲va综合va国产va中文| 国产制服丝袜一区| 亚洲欧美综合视频| 337p粉嫩大胆噜噜噜噜噜91av| 色欲av无码一区二区三区| 中文av一区二区| 希岛爱理中文字幕| 亚洲高清在线精品| 无码人妻精品一区二| 欧美日本乱大交xxxxx| 99精品视频免费看| 日韩不卡在线观看| 国产精品99999| 久久视频在线直播| 成人免费观看在线观看| 国产成人亚洲精品| 高清不卡一区| 精品无码久久久久久久动漫| 加勒比久久综合| 永久免费看av| 亚洲欧美日韩精品一区二区| 色戒在线免费观看| 成人免费的视频| 久久久久久久久福利| 一区二区三区免费观看| 日韩精品一区二区亚洲av| 欧美老肥妇做.爰bbww| 亚洲人午夜射精精品日韩| 在线电影av不卡网址| 爱看av在线| 国产精品视频自在线| av不卡一区| 视频一区在线免费观看| 亚洲性感美女99在线| 丁香啪啪综合成人亚洲| 国产一区二区不卡在线| www.av天天| 亚洲国产美国国产综合一区二区| 波多野结衣爱爱| 精品免费一区二区三区| 国外av在线| 欧美激情亚洲视频| 日韩电影精品| 欧洲久久久久久| 国内精品美女在线观看| 成年网站免费在线观看| 99国产精品国产精品久久| 欧美第一页在线观看| 日韩欧美在线视频免费观看| 性中国xxx极品hd| 中文字幕无线精品亚洲乱码一区 | 国产馆精品极品| 女人十八毛片嫩草av| 天天综合网天天综合色| 国产伦子伦对白视频| 国产一区二区三区在线观看视频| av男人的天堂在线观看| 91在线看www| 欧美第一精品| 亚洲色图38p| 久久精品视频一区二区| 成人免费视频毛片| 精品久久久久一区二区国产| 国产欧美久久久久久久久| 国产精品久久综合av爱欲tv| 综合色就爱涩涩涩综合婷婷| 国产精品国产对白熟妇| 国产成人精品免费在线| 777777国产7777777| 欧美日韩亚洲综合| 国产九色在线| 国产精品福利无圣光在线一区| 麻豆精品99| 国产免费av观看| 麻豆一区二区三| 六月婷婷七月丁香| 欧美日韩亚洲国产一区| 日日夜夜精品免费| 久久久久久久久久久91| 无码国模国产在线观看| 中文字幕一区二区三区四区五区人| 视频一区欧美日韩| 波多野结衣片子| 欧美在线观看视频在线| 国产黄在线播放| 国产精品一区二区在线| 欧美hentaied在线观看| 国产一区二区在线免费播放| 中文字幕成人在线观看| 国产一级片一区二区| 中文字幕亚洲图片| 中文字幕成人| 91视频成人免费| 国产iv一区二区三区| 四虎永久在线精品| 亚洲精品电影网| 欧美第一视频| 亚洲午夜精品久久久中文影院av | 一区二区成人在线视频| 国产特级aaaaaa大片| 欧美日本黄视频| 欧美男男freegayvideosroom| 无码播放一区二区三区| 久久久精品天堂| 波多野结衣毛片| 久久精品国产免费观看| 一区二区三区亚洲变态调教大结局| 日本aa在线观看| 91麻豆6部合集magnet| 中文字幕在线天堂| 久久久91精品国产| 高清精品视频| 看欧美ab黄色大片视频免费| 国产精品久久久久影院| 亚洲第一页综合| 日本精品免费观看| 99久久99久久精品国产片桃花 | 在线观看日韩一区二区| 欧美成人在线免费| 欧美人体视频| 奇米影视四色在线| 五月天中文字幕一区二区| 久久免费看视频| 91精品国产综合久久久久久丝袜| 日韩一区二区久久| 中国1级黄色片| 亚洲成av人片在线观看香蕉| 成人免费看视频网站| 男人草女人视频| 国产亚洲一区二区三区在线观看 | 中文字幕不卡在线视频极品| 日韩一区二区三区在线看| 男人的天堂99| 有坂深雪av一区二区精品| 黄色在线小视频| 国产精品10p综合二区| 蜜桃视频第一区免费观看| 久久精品第一页| 亚洲最新av网址| 国产精东传媒成人av电影| 日本中文字幕观看| 色综合久久九月婷婷色综合|