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

首頁 > 開發 > CSS > 正文

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

2024-07-21 02:02:19
字體:
來源:轉載
供稿:網友
存在的問題:

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

<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>

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

2. 該如何生成版本號,根據什么來產生這個版本號。

可能有人為了解決上面的緩存問題,寫了個JSP標簽,通過標簽讀取JS、css文件的修改時間來作為版本號,從而來解決上面2個問題。但這種方法有下面幾個缺點:
1. 每次請求都要通過標簽讀取讀取文件的修改時間,速度慢。當然你可以把文件的修改時間放到緩存中,這樣也會加到了內存使用量。

2. 在HTML靜態頁面中用不了

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

分享自己項目中的處理方案:

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

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

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

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

#合并CSS
/css/mian.css|/css/common.css all.css
3. 搜索程序目錄下所有JS,CSS文件(包括合并后的),每個文件都壓縮后生成對應的1個新文件。

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

實例:
實例的文件結構如下圖:

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

<%@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; // 是否開發環境%>
<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>



程序運行后JSP的代碼:
復制代碼 代碼如下:

<%@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; // 是否開發環境
%>
<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后綴的文件全部是程序啟動時自動生成的。


實例下載:猛擊此處下載


PS:自己的設計的處理方案并沒有解決"需要JSP中加判斷代碼的問題",主要是因為還沒有找到什么好的辦法去自動刪除1.js,2.js,3.js的3個引用,而插入1個新的all.js的引用,如果那位同學對解決這個問題有好的想法,請不吝賜教。
如果有同學想使用這個組件,建議在測試環境下運行一次后,把修改后的程序直接上傳到正式服務器上,然后去掉這個功能,不然在服務器上每次啟動都調用這個功能還是需要花費一些時間和資源的
其實一直想使用SVN中的版本號來控制緩存,這個是最嚴謹的一個方法,但也因為做起來太復雜,所以一直也沒做起來,以后以后有時間可以再研究。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区二区三区久久| 国产精品成人免费电影| 亚洲黄色成人网| 欧美在线视频一二三| 亚洲天堂男人天堂| 26uuu另类亚洲欧美日本一| 日本sm极度另类视频| 欧美做受高潮电影o| 欧洲一区二区视频| 国产精品高潮呻吟久久av野狼| 国产精品久久久久久久久久久不卡| 中日韩午夜理伦电影免费| 久久理论片午夜琪琪电影网| 欧美激情成人在线视频| 久久精品视频网站| 亚洲美女性生活视频| 91亚洲午夜在线| 国产精品免费视频久久久| 久久影院在线观看| 欧美老女人性生活| 日韩av最新在线观看| 97超碰国产精品女人人人爽| 久久精品男人天堂| 亚洲自拍欧美另类| 91社区国产高清| 欧美日韩激情视频| 亚洲欧洲一区二区三区在线观看| 亚洲国语精品自产拍在线观看| 国产成人avxxxxx在线看| 欧美成人免费视频| 欧美日韩免费在线观看| 久久好看免费视频| 亚洲精品视频在线观看视频| 国产精品无av码在线观看| 在线播放精品一区二区三区| 国产日韩欧美中文| 亚洲国产精品人久久电影| 久久成人在线视频| 国产精品电影在线观看| 国产精品青青在线观看爽香蕉| 日韩精品欧美激情| 日韩中文字在线| 欧美日韩午夜激情| 欧美人与物videos| 成人妇女免费播放久久久| 日韩美女中文字幕| 伊人伊成久久人综合网站| 欧美日本在线视频中文字字幕| 国产一区二区三区日韩欧美| 欧美日韩国产中文精品字幕自在自线| 国产精品91久久久| 国产精品久久中文| 欧美日本啪啪无遮挡网站| 欧美专区在线播放| 日韩av在线看| 亚洲精品久久久久久久久久久久| 91视频88av| 国产免费一区二区三区在线观看| 国内成人精品一区| www.久久草.com| 一区二区三区动漫| 久久久久久久久爱| 日本高清不卡的在线| 欧美黄色成人网| 国产精品久久久久久久久影视| 成人激情在线播放| 亚洲人成网站色ww在线| 日韩中文字幕视频在线观看| 精品一区精品二区| 成人性生交xxxxx网站| 国产精品久久91| 欧美成人免费全部观看天天性色| 国产亚洲精品美女久久久久| 日韩精品视频在线观看免费| 成人国产在线视频| 欧美日韩国产色视频| 日产精品99久久久久久| 精品视频久久久久久久| 黄色成人av网| 亚洲性视频网站| 成人有码视频在线播放| 2021久久精品国产99国产精品| 亚洲剧情一区二区| 久青草国产97香蕉在线视频| 国产精品久久久久久久久久99| 狠狠色香婷婷久久亚洲精品| 亚洲视屏在线播放| 国产经典一区二区| 国产精品爱久久久久久久| 精品美女久久久久久免费| 欧美最猛性xxxxx(亚洲精品)| 亚洲第一精品夜夜躁人人爽| 亚洲国产日韩一区| 国产精品永久免费视频| 久久亚洲私人国产精品va| 91系列在线观看| 69**夜色精品国产69乱| 欧美wwwxxxx| 欧美高清在线观看| 热久久这里只有精品| 亚洲欧美国产日韩天堂区| 一二美女精品欧洲| 欧美影院在线播放| 日韩成人在线播放| 国产精品 欧美在线| 国产精品白嫩美女在线观看| 亚洲精品videossex少妇| 中文字幕日韩免费视频| 久久久免费观看视频| 欧美中文字幕在线| 国产亚洲成av人片在线观看桃| 国产日韩精品综合网站| 国产拍精品一二三| 中文字幕在线看视频国产欧美| 国产成人小视频在线观看| 欧美国产日韩xxxxx| 亚洲欧美一区二区精品久久久| 亚洲性生活视频在线观看| 色妞欧美日韩在线| 亚洲一区免费网站| 成人精品久久av网站| 日韩欧美成人免费视频| 欧美有码在线视频| 成人午夜在线视频一区| 福利一区福利二区微拍刺激| 日韩精品视频免费专区在线播放| 欧美成人中文字幕| 亚洲午夜未删减在线观看| 欧美成人精品三级在线观看| 欧美最顶级丰满的aⅴ艳星| 在线观看视频99| 精品国产欧美一区二区五十路| 国产精品久久av| 欧美在线观看日本一区| 久久精品99无色码中文字幕| 69久久夜色精品国产69乱青草| 91av在线看| 日本高清不卡的在线| 国产亚洲人成网站在线观看| 久久91精品国产91久久久| 久久精品在线视频| 91av成人在线| 国产精品国模在线| 91免费的视频在线播放| 中日韩美女免费视频网站在线观看| 国产日韩在线精品av| 4388成人网| 欧美高清视频一区二区| 久久亚洲影音av资源网| 久久久综合av| 在线a欧美视频| 国产精品久久久久久av下载红粉| 欧美成人全部免费| 久久影视电视剧凤归四时歌| 亚洲黄色在线看| 51精品国产黑色丝袜高跟鞋| 国产精品成人久久久久| 欧美麻豆久久久久久中文| 久久99精品久久久久久青青91| 国产精品视频免费在线观看| 在线观看日韩视频| 日韩精品中文字幕久久臀| 欧美亚洲在线观看| 97久久国产精品|