將nodejs打包工具整合到鼠標右鍵的方法
更新時間:2013年05月11日 17:06:59 作者:
昨天放出了主要的nodejs打包代碼(《nodejs寫的簡單項目打包工具》),今天放出整合到鼠標右鍵的代碼,打包需要配置環(huán)境變量,添加NODE_PATH為node安裝路徑
打包用到的批處理文件代碼如下:
復(fù)制代碼 代碼如下:
@echo off
title Builder - 正在合并 ...
color 03
REM =====================================
REM jsbuilder beta版
REM
REM =====================================
SETLOCAL ENABLEEXTENSIONS
echo.
REM 過濾文件后綴,只combo js文件
if "%~x1" NEQ ".js" (
echo.
echo **** 請選擇JS文件
echo.
goto End
)
REM 檢查NODE_PATH
if "%NODE_PATH%" == "" goto NoNodePath
if not exist "%NODE_PATH%\node.exe" goto NoNodePath
set RESULT_FILE=%~n1-combo%~x1
:ZIP_CHOICE
echo 選擇是否【壓縮】合并后的js文件?
set input=
set /p input= -^> 請選擇(y/n):
if /i "%input%"=="n" goto UNZIP
if /i "%input%"=="y" goto ZIP
REM 調(diào)用build合并文件
:UNZIP
"%NODE_PATH%\node.exe" "%~dp0build.js" --unzip "%~n1%~x1" > "%RESULT_FILE%"
echo.
echo **** ~O(∩_∩)O~ 【合并】成功 ****
echo.
goto End
REM 調(diào)用build合并并且壓縮文件
:ZIP
"%NODE_PATH%\node.exe" "%~dp0build.js" "%~n1%~x1" > "%RESULT_FILE%"
echo.
echo **** ~O(∩_∩)O~ 【合并并壓縮】成功 ****
echo.
goto End
:NoNodePath
echo.
echo **** 請先安裝NodeJS并設(shè)置NODE_PATH環(huán)境變量 ****
echo.
:End
ENDLOCAL
pause
打包用的build.js代碼如下:
復(fù)制代碼 代碼如下:
//加載配置
require('./config.js');
//用到的模塊
var FS = require('fs'),
PATH = require('path'),
jscombo = require('./tool/jscombo'),
Util = require('util');
//獲取參數(shù)
var args = process.argv;
args = [].slice.call(args,2);
var opts = {};//配置
var curPath, rootPath = curPath = process.cwd();
//根據(jù)config.js的相對路徑設(shè)置,變換rootPath
if(typeof relativePath!=='undefined'){
rootPath = PATH.join(rootPath,relativePath);
}
var filename;//要處理的文件名字
//處理參數(shù)
out: while(args.length){
var v = args.shift();
switch(v){
case '-uz':
case '--unzip':
//combo后壓縮
opts.unzip = true;
break;
default:
filename = v;
break out;
}
}
// var filePath = PATH.join(rootPath,filename);
//將要壓縮的js文件路徑 轉(zhuǎn)化為相對rootpath的路徑
var rPath = PATH.relative(rootPath,PATH.join(curPath,filename));
var str = jscombo(rPath, rootPath, opts);
var fileout = process.stdout;
fileout.write(str);
您可能感興趣的文章:
- js調(diào)試工具console.log()方法查看js代碼的執(zhí)行情況
- node.js版本管理工具n無效的原理和解決方法
- js實現(xiàn)帶關(guān)閉按鈕始終顯示在網(wǎng)頁最底部工具條的方法
- PHP小技巧之JS和CSS優(yōu)化工具Minify的使用方法
- JavaScript1.6數(shù)組新特性介紹以及JQuery的幾個工具方法
- js工具方法彈出蒙版
- 常用Extjs工具:Extjs.util.Format使用方法
- 一款js和css代碼壓縮工具[附JAVA環(huán)境配置方法]
- 解決http://16a.us/2.js之a(chǎn)rp欺騙的方法附專殺工具
- Angular工具方法學習
相關(guān)文章
js解析與序列化json數(shù)據(jù)(二)序列化探討
上一節(jié)我們講解了JSON.stringify()的基本用法,這一節(jié)我們來重點探討一下序列化,單獨或組合使用這兩個參數(shù)(過濾器/數(shù)組),可以更全面深入地控制JSON的序列化,感興趣的朋友可以了解下,或許對你學習json有所幫助2013-02-02javascript操作JSON的要領(lǐng)總結(jié)
JSON是 JavaScript 原生格式,這意味著在 JavaScript 中處理 JSON數(shù)據(jù)不須要任何特殊的 API 或工具包,需要的朋友可以了解下2012-12-12用JSON做數(shù)據(jù)傳輸格式中的一些問題總結(jié)
Json 憑借其自身的優(yōu)勢,在Web數(shù)據(jù)處理方面已經(jīng)占據(jù)了一定的位置,這段時間涉及到用Json做為數(shù)據(jù)傳輸格式的項目有3個,其中有部分頁面就采用了Json 數(shù)據(jù)傳輸格式, 這里我總結(jié)下這段時間采用這種方式的一些問題總結(jié)2011-12-12使Ext的Template可以解析二層的json數(shù)據(jù)的方法
2007-12-12