亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發(fā) > CSS > 正文

高性能WEB開發(fā) JS、CSS的合并、壓縮、緩存管理

2024-07-21 02:02:19
字體:
供稿:網(wǎng)友
存在的問題:

合并、壓縮文件主要有2方面的問題:
1. 每次發(fā)布的時(shí)候需要運(yùn)行一下自己寫的bat文件或者其他程序把文件按照自己的配置合并和壓縮。
2. 因生產(chǎn)環(huán)境和開發(fā)環(huán)境需要加載的文件不一樣,生產(chǎn)環(huán)境為了需要加載合并、壓縮后的文件,而開發(fā)環(huán)境為了修改、調(diào)試方便,需要加載非合并、壓縮的文件,所以我們常常需要在JSP中類似與下面的判斷代碼:
復(fù)制代碼 代碼如下:

<c:if test="${env=='prod'}">
<script type="text/javascript" src="/js/all.js"></script>
</c:if>
<c:if test="${env=='dev'}">
<script type="text/javascript" src="/js/1.js"></script>
<script type="text/javascript" src="/js/2.js"></script>
<script type="text/javascript" src="/js/3.js"></script>
</c:if>

緩存問題:在現(xiàn)在JS滿天飛的時(shí)代,大家都知道緩存能帶來的巨大好處,但緩存確實(shí)非常麻煩的一個(gè)問題,相信很多人曾經(jīng)歷過下面的情況:為了讓程序更快,在服務(wù)器上為JS加上緩沖5天的代碼,但產(chǎn)品更新后第二天就接到電話說系統(tǒng)出錯(cuò),詳細(xì)了解后就發(fā)現(xiàn)是緩存引起的,讓用戶刪除緩存后就會(huì)OK。原因很簡(jiǎn)單,就是你JS已經(jīng)修改了,但用戶還在使用緩存中的老JS。在經(jīng)歷幾次這種情況,被領(lǐng)導(dǎo)數(shù)落了幾次后。沒辦法只能把JS的緩沖去掉,或者改成8個(gè)小時(shí)??蛇@樣就完全失去了緩存的優(yōu)勢(shì)了,哪我們到底需要解決哪些問題才能讓我們使用緩沖順心如意了?
1. 如何在修改了某個(gè)JS后,自動(dòng)把所有引用該JS頁面的代碼中加上1個(gè)版本號(hào)?

2. 該如何生成版本號(hào),根據(jù)什么來產(chǎn)生這個(gè)版本號(hào)。

可能有人為了解決上面的緩存問題,寫了個(gè)JSP標(biāo)簽,通過標(biāo)簽讀取JS、css文件的修改時(shí)間來作為版本號(hào),從而來解決上面2個(gè)問題。但這種方法有下面幾個(gè)缺點(diǎn):
1. 每次請(qǐng)求都要通過標(biāo)簽讀取讀取文件的修改時(shí)間,速度慢。當(dāng)然你可以把文件的修改時(shí)間放到緩存中,這樣也會(huì)加到了內(nèi)存使用量。

2. 在HTML靜態(tài)頁面中用不了

3. 如果你們公司是如下的部署發(fā)布方式(我們公司就是這樣),則會(huì)失效。每次發(fā)布,不是直接覆蓋之前的WEB目錄,運(yùn)維的為的發(fā)布方便,要求每次發(fā)布直接給他們1個(gè)war包,他們會(huì)把之前WEB目錄整個(gè)刪除,然后上傳現(xiàn)在的war包,這樣就導(dǎo)致程序運(yùn)行后,所有文件的最后修改時(shí)間都是解壓war的時(shí)間。

分享自己項(xiàng)目中的處理方案:

為了解決上面討論過的問題,在下寫了1個(gè)如下的組件,組件中根據(jù)我們自己的實(shí)際情況使用了文件大小來做為文件的版本號(hào),雖然在文件修改很小(比如把字符a改成b),可能文件大小并沒有變,導(dǎo)致版本號(hào)也不會(huì)變。

但這種機(jī)率還是非常低的。當(dāng)然如果你覺的使用文件修改時(shí)間作為版本號(hào)適合你,只需要修改一行代碼就行,下面看下這個(gè)組件的處理流程(本來想用流程圖表達(dá),最后還是覺的文字來的直白寫):
1. 程序啟動(dòng)(contextInitialized)

2. 搜索程序目錄下的所有merge.txt文件,根據(jù)merge.txt文件的配置合并文件, merge.txt文件實(shí)例如下:
# 文件合并配置文件,多個(gè)文件以|隔開,以/開頭的表示從根目錄開始,
# 空格之后的文件名表示合并之后的文件名

# 把1,2,3合并到all文件中
1.js|2.js|3.js all.js

#合并CSS
/css/mian.css|/css/common.css all.css
3. 搜索程序目錄下所有JS,CSS文件(包括合并后的),每個(gè)文件都?jí)嚎s后生成對(duì)應(yīng)的1個(gè)新文件。

4. 搜索程序目錄下所有JSP,html文件,把所有JS,css的引用代碼改成壓縮后并加了版本號(hào)的引用。

實(shí)例:
實(shí)例的文件結(jié)構(gòu)如下圖:

看JSP原始代碼(程序運(yùn)行前):
復(fù)制代碼 代碼如下:

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<% boolean isDev = false; // 是否開發(fā)環(huán)境%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>JSP Page</title>
<% if(isDev){ %>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/jquery-1.4.2.js"></script>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/1.js"></script>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/2.js"></script>
<link type="text/css" rel="stylesheet" href="<%=request.getContextPath() %>/css/1.css" />
<link type="text/css" rel="stylesheet" href="<%=request.getContextPath() %>/css/2.css" />
<% }else{ %>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/jquery-1.4.2.js"></script>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/all.js"></script>
<link type="text/css" rel="stylesheet" href="<%=request.getContextPath() %>/css/all.css" />
<% } %>
</head>
<body>
<h1 class="c1">Hello World!</h1>
</body>
</html>



程序運(yùn)行后JSP的代碼:
復(fù)制代碼 代碼如下:

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%
boolean isDev = false; // 是否開發(fā)環(huán)境
%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>JSP Page</title>
<% if(isDev){ %>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/jquery-1.4.2-3gmin.js?99375"></script>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/1-3gmin.js?90"></script>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/2-3gmin.js?91"></script>
<link type="text/css" rel="stylesheet" href="<%=request.getContextPath() %>/css/1-3gmin.css?35" />
<link type="text/css" rel="stylesheet" href="<%=request.getContextPath() %>/css/2-3gmin.css?18" />
<% }else{ %>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/jquery-1.4.2-3gmin.js?99375"></script>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/all-3gmin.js?180"></script>
<link type="text/css" rel="stylesheet" href="<%=request.getContextPath() %>/css/all-3gmin.css?53" />
<% } %>
</head>
<body>
<h1 class="c1">Hello World!</h1>
</body>
</html>

加3gmin后綴的文件全部是程序啟動(dòng)時(shí)自動(dòng)生成的。


實(shí)例下載:猛擊此處下載


PS:自己的設(shè)計(jì)的處理方案并沒有解決"需要JSP中加判斷代碼的問題",主要是因?yàn)檫€沒有找到什么好的辦法去自動(dòng)刪除1.js,2.js,3.js的3個(gè)引用,而插入1個(gè)新的all.js的引用,如果那位同學(xué)對(duì)解決這個(gè)問題有好的想法,請(qǐng)不吝賜教。
如果有同學(xué)想使用這個(gè)組件,建議在測(cè)試環(huán)境下運(yùn)行一次后,把修改后的程序直接上傳到正式服務(wù)器上,然后去掉這個(gè)功能,不然在服務(wù)器上每次啟動(dòng)都調(diào)用這個(gè)功能還是需要花費(fèi)一些時(shí)間和資源的
其實(shí)一直想使用SVN中的版本號(hào)來控制緩存,這個(gè)是最嚴(yán)謹(jǐn)?shù)囊粋€(gè)方法,但也因?yàn)樽銎饋硖珡?fù)雜,所以一直也沒做起來,以后以后有時(shí)間可以再研究。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国产美女高潮在线观看| 亚洲v日韩v欧美v综合| 91在线观看免费视频| 日韩视频在线一区二区三区| 一区二区三区国产精品| 亚洲国产精品久久艾草纯爱| 中文字幕黄色大片| 一区二区三区精品在线| 四虎永久在线高清国产精品| 日本高清视频网站| 国产精品日本一区二区| 2020欧美日韩在线视频| 91丨porny丨在线中文| 国产97人人超碰caoprom| 日韩第一页在线| 亚洲大片精品免费| www.麻豆av.com| 国产精品视频最多的网站| 永久555www成人免费| 国产精品区二区三区日本| 色系列之999| 欧美精品一区二区三| 一区二区三区韩国免费中文网站| 久久高清免费| 9色porny| 正在播放久久| 韩国欧美国产一区| 亚洲福利在线观看| 欧美日本一道| 欧美亚洲第一区| 久久久精品中文字幕| 韩国精品视频| 992kp快乐看片永久免费网址| 91国偷自产一区二区开放时间| 黄色三及免费看| www.狠狠lu| 91tv亚洲精品香蕉国产一区7ujn| 午夜免费视频网站| 亚洲性视频在线| 国产欧美一区二区三区精品观看| 亚洲欧美中文日韩v在线观看| 在线观看黄色国产| 四虎影视在线播放| 青青草成人影院| 亚洲免费观看高清完整版在线观| wwwww黄色| 欧美大胆a级| 日韩精品视频中文在线观看| 欧美特级黄色片| 欧美婷婷六月丁香综合色| 亚洲精品成人在线视频| 四虎成人av| 99精品一区二区三区无码吞精| 色拍拍在线精品视频8848| 亚欧洲精品视频在线观看| 99re热久久这里只有精品34| 葵司免费一区二区三区四区五区| 91成人国产在线观看| 性猛交ⅹ×××乱大交| 麻豆最新免费在线视频| 久久综合九九| 亚洲品质自拍视频网站| 日本高清免费观看| 亚洲激情免费视频| 在线观看精品一区| 在线精品亚洲一区二区不卡| 精品视频网站| 久久亚洲精品国产| 精品国产区在线| 日韩欧美视频一区二区三区| 无码粉嫩虎白一线天在线观看| 欧美xxxx黑人又粗又长密月| 在线观看二区| 蜜桃传媒在线观看免费进入| 性网站在线观看| 国产 欧美在线| 日本视频一区二区不卡| 国产a级免费视频| 日韩avvvv在线播放| 亚洲精品蜜桃乱晃| 麻豆国产在线视频| 天天影视久久综合| 久久精品视频免费| 蜜臀aⅴ国产精品久久久国产老师| 精品女同一区二区三区在线播放| 97人妻精品一区二区三区动漫| 男人的午夜天堂| 久热中文在线| 九九热这里只有在线精品视| 成人亚洲免费视频| 欧美久久久精品| 97自拍视频| 国产二区三区在线| 中文字幕高清不卡| 国产日韩av在线| 在线观看免费播放网址成人| 国产精品久久久久一区二区| 黄色一区二区三区四区| 日韩午夜高潮| 波多野结衣小视频| 成人午夜精品在线| 毛片av在线| 2024国产精品| 在线免费中文字幕| 飘雪影院手机免费高清版在线观看| 成人免费高清视频在线观看| 国产综合色激情| 日韩午夜电影| 自拍偷拍色综合| 久久日文中文字幕乱码| а天堂中文在线资源| 91成人福利在线| 99国产精品久久久久久久| caoporn免费在线视频| 免费成人在线看| 欧美精品momsxxx| 国产白袜脚足j棉袜在线观看| 天堂中文在线观看| 欧美69精品久久久久久不卡| 五月激情六月综合| 久久国产精品久久久久久| 亚洲国产精品久久久久| 99三级在线| 欧美系列精品| 天堂av在线电影| 午夜a一级毛片亚洲欧洲| 都市激情亚洲| 欧美性猛交xxxx乱大交3| 国产偷国产偷亚洲高清97cao| 国产精品久久久久久av福利| 国产精品igao视频网网址不卡日韩| xxav视频| 久久久久久久一区二区三区| 精品成人av一区二区在线播放| 97色在线播放视频| 国产精品一区二区三区四区五区| 欧美男女交配视频| 99久热在线精品996热是什么| 国产成人综合网站| 男人的天堂av高清在线| 视频精品一区| 波多野结衣成人在线| 国产精品久久网站| 精品人妻一区二区免费视频| www日韩精品| 亚洲大片免费观看| 久艹视频在线观看| 很黄很黄激情成人| 国产福利精品av综合导导航| 在线中文字日产幕| 亚洲精品二区三区| 女性女同性aⅴ免费观女性恋| 日本电影一区二区| 天天色天天射综合网| 欧美精品亚洲二区| 亚洲一区二区在线免费观看视频| 热国产热中文视频二区| 亚洲日本韩国在线| 少妇精品视频在线观看| 日韩一区二区麻豆国产| 亚洲激情视频一区| 日韩激情精品| 妖精一区二区三区精品视频| 最近中文字幕mv2018在线高清| 久久精品亚洲精品| 亚洲欧美日韩一区在线| 日韩av一级电影| 99re6这里只有精品| 久久久久久免费视频| 国产裸舞福利在线视频合集| 午夜精品久久久久久久蜜桃app| 樱桃成人精品视频在线播放| 成人污网站在线观看| 日本道免费精品一区二区三区| 91九色老女人| 国产精品无码专区在线观看| 午夜毛片在线| 400部精品国偷自产在线观看| 亚洲第一色网站| 麻豆久久久av免费| 日本韩国在线不卡| 熟妇女人妻丰满少妇中文字幕| eeuss影院18直达| 久久久久久国产精品久久| 特级西西444www大精品视频| 日韩在线观看免费网站| 中文字幕亚洲影院| 91嫩草国产线观看亚洲一区二区| 91大神在线播放精品| 亚洲韩国在线| 国产亚洲一区二区在线| 精品在线视频免费| 国产精品久久久av| 欧美日韩亚洲国产另类| 激情综合在线观看| 欧美日韩一级在线观看| 777午夜精品免费视频| 日本电影在线观看| 可以免费观看的黄色网址| 婷婷丁香综合网| 亚洲女人被黑人巨大进入al| 99精品一级欧美片免费播放| 日韩一二三在线视频播| 成人羞羞视频播放网站| 免费三级毛片| 青青草成人在线| 99re66热这里只有精品3直播| 日韩一区二区三区不卡视频| 成人av片网址| 久久精品亚洲麻豆av一区二区| 三区在线观看| 日日干天天干| 国产精品亚洲第五区在线| y111111国产精品久久婷婷| 亚洲专区**| 亚洲国产精品热久久| 在线免费视频一区| jizzjizz中文| 亚洲国产女人aaa毛片在线| 日韩专区中文字幕一区二区| free性m.freesex欧美| 亚洲三级免费看| 免费黄色片视频| 欧美尤物一区| 国产高潮流白浆喷水视频| 中文字幕97| 成人黄色大片在线观看| 波多野结衣办公室33分钟| 日韩欧美电影在线观看| 四虎国产精品免费| 国产成人精品久久二区二区91| 国产午夜精品免费一区二区三区| 女同另类激情重口| 亚洲精品日韩久久| 精品一区二区三区日韩| 情侣黄网站免费看| 欧美 日韩 国产 一区二区三区| 丁香花高清电影在线观看完整版| 97超碰在线资源站| 超碰日本道色综合久久综合| 国产激情视频一区二区三区| a优女a优女片| 国产又粗又长又爽| 久久精品亚洲天堂| 欧美亚洲一二三区| 久久最新网址| 婷婷综合久久一区二区三区| 日韩激情图片| 91tv亚洲精品香蕉国产一区7ujn| 欧美美女喷水视频| 久久成人免费视频| 久久综合电影| 久久久久久久综合狠狠综合| 麻豆成全视频免费观看在线看| 性做久久久久久免费观看| 在线观看日本视频| 日韩在线理论| 日本丰满少妇裸体自慰| 欧美成人精品3d动漫h| h网址在线观看| 国产高清视频一区三区| 亚洲精品一品区二品区三品区| 亚洲一区视频在线播放| 日本黄网站色大片免费观看| 日本成人a网站| 午夜福利视频一区二区| 伊人再见免费在线观看高清版| www.天堂在线| igao视频网在线视频| 8v天堂国产在线一区二区| av免费观看一区二区| 国产婷婷精品av在线| 超碰人人干人人| 欧美在线日韩在线| 古典武侠综合av第一页| 国产午夜精品一区二区三区嫩草| 中文字幕在线播出| 粉嫩13p一区二区三区| 奴色虐av一区二区三区| 亚洲成人免费网站| 国产99亚洲| 久久亚洲精品大全| 国产精品.com| 国产在线观看黄色| 极品粉嫩国产18尤物| 亚洲日本一区二区三区在线不卡| 成人私拍视频| 日韩黄色在线观看| 成年人小视频网站| 国产亚洲欧美日韩俺去了| 欧美国产日韩激情| 色国产在线视频| 国产在线精品一区在线观看麻豆| 欧美下载看逼逼| 成人免费在线视频播放| 四虎精品影院在线观看视频| 99蜜桃臀久久久欧美精品网站| 国产在线国偷精品免费看| 日本最新在线视频| 亚洲综合日韩中文字幕v在线| 日韩精品在线影院| 日本精品视频在线| 国产欧美一区二区三区小说| 91九色在线porn| 男女羞羞视频教学| 国产又色又爽又黄的| 亚洲产国偷v产偷v自拍涩爱| 国产亚洲欧美一区在线观看| 四虎电影网址| 精品一区二三区| 91在线观看高清| 成人av电影观看| 深夜福利网站| 精品国产三级a∨在线| 欧美视频国产视频| 中文字幕制服丝袜在线| 天堂v在线视频| 欧美日韩国产片| 中文字幕 亚洲视频| 日韩欧美亚洲系列| 久久9999免费视频| 久久精品国产99精品国产亚洲性色| 日韩精品看片| 新欧美整片sss第一页| 日韩一级视频| 一区二区不卡在线视频 午夜欧美不卡'| 精品在线视频一区| 久久久久国产免费免费|