JavaScript(JS) 壓縮 / 混淆 / 格式化 批處理工具
昨天分享了 http://jscompress.sinaapp.com/ 這個小工具后,發(fā)現(xiàn)大家還是很喜愛的。
因此今天我把它json化了.用json傳輸數(shù)據(jù),也開放了api
本工具所有的功能實現(xiàn)都是由 http://jscompress.sinaapp.com/api 處理.(包括現(xiàn)在可以使用的這個在線壓縮)
所有的數(shù)據(jù)交換均由 HTTP POST 輸入處理后由 json 作為數(shù)據(jù)輸出格式.
get={type},{type} 為可選的 compress (壓縮) format (格式化) shuffle(混淆)
code=(code),(code) 為必要的源代碼. JavaScript的源代碼
type={compress},{compress} 注意該參數(shù)只有壓縮的時候生效,可選 1(默認壓縮) 2(YUI壓縮) 3(GC壓縮)
例:使用 CURL... POST
如果執(zhí)行成功則返回結果:
{"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%"}
然后我寫了一個php文件,可以調用這個網(wǎng)站的api,把整個目錄所有的js文件壓縮或者混淆,格式化后保存到一個新目錄。
這樣就對那些懶上傳文件的同學們基于方便了~~
直接下載地址: jstools.rar
高亮顯示
<?php
/*
/## js 合并和壓縮PHP腳本...可用于本地或者服務器.
/## 本工具只能處理utf-8編碼的 *.js 文件.否則會接收不到結果
@ 風吟 (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, // 是否需要把全部文件合并再進行處理 (壓縮,格式化,混淆)
'engine' =>'1'//此項只對 type 為 compress 時有效,1(默認) 2 (yui) 3(Closure Compiler)
/*
yui 和 Google Closure Compiler 壓縮是不可逆的,一般情況下使用默認即可
不推薦使用混淆.
*/
)){
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ù)代碼腳本之家修正版
- JavaScript性能優(yōu)化 創(chuàng)建文檔碎片(document.createDocumentFragment)
- 自己整理的一個javascript日期處理函數(shù)
- 高性能Javascript筆記 數(shù)據(jù)的存儲與訪問性能優(yōu)化
- javascript強大的日期函數(shù)代碼分享
- JavaScript中的無阻塞加載性能優(yōu)化方案
- javascript中日期函數(shù)new Date()的瀏覽器兼容性問題
- javascript日期處理函數(shù),性能優(yōu)化批處理
相關文章
JavaScript實現(xiàn)一個前端會魔法的旋轉魔方相冊
星光不問趕路人,時光不誤有心人,牛牛最近學到了一個神奇的旋轉魔方,今天就來分享給大家吧,希望大家能喜歡2022-06-06JavaScript HTML DOM元素 節(jié)點操作匯總
這篇文章主要介紹了JavaScript HTML DOM元素 節(jié)點操作匯總,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-07-07