JavaScript(JS) 壓縮 / 混淆 / 格式化 批處理工具
昨天分享了 http://jscompress.sinaapp.com/ 這個(gè)小工具后,發(fā)現(xiàn)大家還是很喜愛的。
因此今天我把它json化了.用json傳輸數(shù)據(jù),也開放了api
本工具所有的功能實(shí)現(xiàn)都是由 http://jscompress.sinaapp.com/api 處理.(包括現(xiàn)在可以使用的這個(gè)在線壓縮)
所有的數(shù)據(jù)交換均由 HTTP POST 輸入處理后由 json 作為數(shù)據(jù)輸出格式.
get={type},{type} 為可選的 compress (壓縮) format (格式化) shuffle(混淆)
code=(code),(code) 為必要的源代碼. JavaScript的源代碼
type={compress},{compress} 注意該參數(shù)只有壓縮的時(shí)候生效,可選 1(默認(rèn)壓縮) 2(YUI壓縮) 3(GC壓縮)
例:使用 CURL... POST
如果執(zhí)行成功則返回結(jié)果:
{"code":"var a=1,b=2;\n","original_size":"16 Byte","now_size":"13 Byte","status":"Closure Compiler \u538b\u7f29\u5b8c\u6210.","minify":"81.25%"}
然后我寫了一個(gè)php文件,可以調(diào)用這個(gè)網(wǎng)站的api,把整個(gè)目錄所有的js文件壓縮或者混淆,格式化后保存到一個(gè)新目錄。
這樣就對(duì)那些懶上傳文件的同學(xué)們基于方便了~~
直接下載地址: jstools.rar
高亮顯示
<?php
/*
/## js 合并和壓縮PHP腳本...可用于本地或者服務(wù)器.
/## 本工具只能處理utf-8編碼的 *.js 文件.否則會(huì)接收不到結(jié)果
@ 風(fēng)吟 (fengyin.name)
@ http://jscompress.sinaapp.com/
*/
set_time_limit(0);
function JsTools($options = array(
'basepath' =>'./', //需要處理的腳本路徑...
'compiled' =>'./compiled/', //處理后新文件的路徑...
'type' =>'compress', //可選 compress (壓縮) format (格式化) shuffle (混淆)
'is_merger' =>true, // 是否需要把全部文件合并再進(jìn)行處理 (壓縮,格式化,混淆)
'engine' =>'1'//此項(xiàng)只對(duì) type 為 compress 時(shí)有效,1(默認(rèn)) 2 (yui) 3(Closure Compiler)
/*
yui 和 Google Closure Compiler 壓縮是不可逆的,一般情況下使用默認(rèn)即可
不推薦使用混淆.
*/
)){
if (is_dir($options['basepath'])) {
if ($dh = opendir($options['basepath'])) {
while (($file = readdir($dh)) !== false) {
if (strpos($file, '.js') !== false && strpos($file, '.min.js') === false) {
$js[] = $file;
}
}
closedir($dh);
}
}
if ($options['is_merger']) {
foreach($js as $jsfile) {
$jscode.= file_get_contents($jsfile).';';
}
$jscode = json_decode(api($jscode, $options['type'], $options['engine']), true);
file_put_contents($options['compiled'].'all.min.js', $jscode['code']);
} else {
foreach($js as $jsfile) {
$jscode = json_decode(api(file_get_contents($jsfile), $options['type'], $options['engine']), true);
file_put_contents($options['compiled'].str_replace('.js', '.min.js', $jsfile), $jscode['code']);
}
}
}
function api($code, $type, $engine) {
$ch = curl_init('http://jscompress.sinaapp.com/api');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, 'get='.$type.'&code='.urlencode($code).'&type='.$engine);
$output = curl_exec($ch);
curl_close($ch);
return $output;
}
JsTools();
?>
- 巧用批處理解決IE不支持JavaScript等問題
- javascript 格式化時(shí)間日期函數(shù)代碼腳本之家修正版
- JavaScript性能優(yōu)化 創(chuàng)建文檔碎片(document.createDocumentFragment)
- 自己整理的一個(gè)javascript日期處理函數(shù)
- 高性能Javascript筆記 數(shù)據(jù)的存儲(chǔ)與訪問性能優(yōu)化
- javascript強(qiáng)大的日期函數(shù)代碼分享
- JavaScript中的無阻塞加載性能優(yōu)化方案
- javascript中日期函數(shù)new Date()的瀏覽器兼容性問題
- javascript日期處理函數(shù),性能優(yōu)化批處理
相關(guān)文章
js閉包的6種應(yīng)用場(chǎng)景總結(jié)
如果一個(gè)函數(shù)訪問了此函數(shù)的父級(jí)及父級(jí)以上的作用域變量,那么這個(gè)函數(shù)就是一個(gè)閉包,本文將給大家分享js閉包的6種應(yīng)用場(chǎng)景,文中有詳細(xì)的代碼示例,需要的朋友可以參考下2023-09-09JavaScript實(shí)現(xiàn)一個(gè)前端會(huì)魔法的旋轉(zhuǎn)魔方相冊(cè)
星光不問趕路人,時(shí)光不誤有心人,牛牛最近學(xué)到了一個(gè)神奇的旋轉(zhuǎn)魔方,今天就來分享給大家吧,希望大家能喜歡2022-06-06微信公眾平臺(tái)獲取access_token的方法步驟
這篇文章主要介紹了微信公眾平臺(tái)獲取access_token的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03JavaScript HTML DOM元素 節(jié)點(diǎn)操作匯總
這篇文章主要介紹了JavaScript HTML DOM元素 節(jié)點(diǎn)操作匯總,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07JS幾個(gè)常用的函數(shù)和對(duì)象定義與用法示例
這篇文章主要介紹了JS幾個(gè)常用的函數(shù)和對(duì)象定義與用法,涉及JavaScript日期時(shí)間、數(shù)值計(jì)算及變量判斷等相關(guān)操作技巧,需要的朋友可以參考下2020-01-01