亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 高性能WEB開發(fā) JS、CSS的合并、壓縮、緩存管理

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

熱門標(biāo)簽:忻州外呼系統(tǒng)接口對接 語音平臺系統(tǒng) 醫(yī)院地圖標(biāo)注 嘟聲的電銷機(jī)器人 洛陽便宜外呼系統(tǒng)廠家 湖北穩(wěn)定外呼系統(tǒng) 地圖標(biāo)注和圖片標(biāo)注 電銷機(jī)器人怎么收費 滄州智能外呼系統(tǒng)收費
存在的問題:

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

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

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

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

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

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

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

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

2. 搜索程序目錄下的所有merge.txt文件,根據(jù)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文件(包括合并后的),每個文件都壓縮后生成對應(yīng)的1個新文件。

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

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

看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.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的代碼:
復(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后綴的文件全部是程序啟動時自動生成的。


實例下載:猛擊此處下載


PS:自己的設(shè)計的處理方案并沒有解決"需要JSP中加判斷代碼的問題",主要是因為還沒有找到什么好的辦法去自動刪除1.js,2.js,3.js的3個引用,而插入1個新的all.js的引用,如果那位同學(xué)對解決這個問題有好的想法,請不吝賜教。
如果有同學(xué)想使用這個組件,建議在測試環(huán)境下運行一次后,把修改后的程序直接上傳到正式服務(wù)器上,然后去掉這個功能,不然在服務(wù)器上每次啟動都調(diào)用這個功能還是需要花費一些時間和資源的
其實一直想使用SVN中的版本號來控制緩存,這個是最嚴(yán)謹(jǐn)?shù)囊粋€方法,但也因為做起來太復(fù)雜,所以一直也沒做起來,以后以后有時間可以再研究。
您可能感興趣的文章:
  • CSS3 動畫卡頓性能優(yōu)化的完美解決方案
  • js中用事實證明cssText性能高的問題
  • 微信小程序 扭蛋抽獎機(jī)css3動畫實現(xiàn)詳解
  • vue操作動畫的記錄animate.css實例代碼
  • Vue中CSS動畫原理的實現(xiàn)
  • 原生JS檢測CSS3動畫是否結(jié)束的方法詳解
  • 微信小程序CSS3動畫下拉菜單效果
  • 詳解盒子端CSS動畫性能提升

標(biāo)簽:防城港 定州 巴彥淖爾 內(nèi)蒙古 96 日照 宜賓 山南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《高性能WEB開發(fā) JS、CSS的合并、壓縮、緩存管理》,本文關(guān)鍵詞  高性能,WEB,開發(fā),CSS,的,合并,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《高性能WEB開發(fā) JS、CSS的合并、壓縮、緩存管理》相關(guān)的同類信息!
  • 本頁收集關(guān)于高性能WEB開發(fā) JS、CSS的合并、壓縮、緩存管理的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    国产精品自拍在线| 国产a视频精品免费观看| 国产精品自拍在线| 二级特黄绝大片免费视频大片| 国产一区二区精品| 91麻豆精品国产自产在线| 日韩免费在线视频| 国产成+人+综合+亚洲不卡| 99色视频在线| 可以免费看污视频的网站| 国产欧美精品| 韩国毛片| 久久精品免视看国产明星| 日本特黄特黄aaaaa大片| 国产一区二区精品| 国产不卡高清| 亚欧成人乱码一区二区| 精品国产亚一区二区三区| 精品在线观看国产| 国产成人啪精品| 成人高清免费| 国产高清在线精品一区二区| 日韩男人天堂| 国产伦精品一区二区三区无广告| 久久99这里只有精品国产| 99久久网站| 国产原创中文字幕| 成人免费网站久久久| 欧美日本国产| 欧美1区2区3区| 99久久精品费精品国产一区二区| 亚欧视频在线| 九九久久99| 久久久成人网| 欧美激情一区二区三区在线 | 欧美大片a一级毛片视频| 国产成a人片在线观看视频| 欧美爱色| 九九久久99综合一区二区| 韩国三级香港三级日本三级la | 欧美一级视| 高清一级毛片一本到免费观看| 国产精品自拍亚洲| 毛片成人永久免费视频| 天天综合在线观看 | 黄视频网站在线看| 国产网站免费视频| 国产不卡在线观看| 亚久久伊人精品青青草原2020| 91麻豆精品国产高清在线| 免费国产在线观看不卡| 亚洲精品永久一区| 国产91精品露脸国语对白| 91麻豆精品国产综合久久久| 久久99中文字幕久久| 日韩综合| 韩国毛片免费大片| 午夜激情视频在线观看| 九九久久国产精品| 你懂的国产精品| 精品视频一区二区三区| 日韩在线观看免费| 欧美1区2区3区| 高清一级毛片一本到免费观看| 日韩在线观看免费| 毛片的网站| 午夜在线影院| 成人免费福利片在线观看| 亚洲精品久久久中文字| 国产麻豆精品| 欧美激情在线精品video| 成人高清免费| 青青久久精品| a级精品九九九大片免费看| 国产高清在线精品一区二区| 九九免费精品视频| 九九精品影院| 精品国产一级毛片| 欧美激情一区二区三区在线播放 | 午夜在线亚洲| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 麻豆网站在线看| 欧美另类videosbestsex视频| 国产伦久视频免费观看 视频| 九九九国产| 欧美电影免费看大全| 久久精品店| 国产精品1024在线永久免费| 欧美1区| 午夜欧美成人香蕉剧场| 久久99爰这里有精品国产| 欧美激情在线精品video| 午夜在线影院| 精品国产一区二区三区久久久蜜臀 | 欧美一级视频高清片| 日韩在线观看网站| 精品久久久久久中文字幕2017| 久久国产影院| 国产精品123| 国产精品123| 精品国产一区二区三区久久久蜜臀 | 久久久成人网| 国产成人啪精品| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 美女被草网站| 99热精品在线| 免费毛片基地| 国产一级强片在线观看| 欧美激情一区二区三区视频高清 | 999精品视频在线| 久久精品大片| 亚洲精品中文字幕久久久久久| 999精品影视在线观看| 久久国产精品永久免费网站| 国产伦久视频免费观看 视频| 精品视频在线观看免费| 欧美日本二区| 国产视频在线免费观看| 高清一级做a爱过程不卡视频| 毛片成人永久免费视频| 午夜在线亚洲男人午在线| 毛片的网站| 日韩中文字幕一区| 久久精品人人做人人爽97| 国产91丝袜在线播放0| 精品视频一区二区| 亚洲女初尝黑人巨高清在线观看| 可以免费在线看黄的网站| 午夜家庭影院| 青青久久国产成人免费网站| 日本在线不卡视频| 国产一区精品| 精品视频免费在线| 麻豆系列 在线视频| 国产成人精品综合久久久| 精品久久久久久免费影院| 成人a大片在线观看| 国产一区二区精品久久91| 久久国产影院| 99久久网站| 欧美激情一区二区三区视频高清 | 在线观看成人网| 国产网站免费| 成人高清视频在线观看| 欧美日本二区| 久久精品道一区二区三区| 国产不卡高清| 日韩一级黄色大片| 欧美一级视| 国产原创视频在线| 国产国产人免费视频成69堂| 二级片在线观看| 国产原创视频在线| 99热精品一区| 欧美一区二区三区在线观看| 四虎久久影院| 久久国产一久久高清| 国产精品自拍在线观看| 国产a一级| 国产成人精品影视| 亚洲精品中文一区不卡| 毛片成人永久免费视频| 国产国产人免费视频成69堂| 国产91素人搭讪系列天堂| 四虎影视库| 99久久网站| 久久精品人人做人人爽97| 精品视频免费观看| 亚欧视频在线| 国产一区二区精品在线观看| 二级特黄绝大片免费视频大片| 九九久久国产精品大片| 青青久久网| 99色视频在线观看| 韩国三级香港三级日本三级| 欧美另类videosbestsex视频| 日韩在线观看视频黄| 欧美激情影院| 午夜欧美成人香蕉剧场| 麻豆午夜视频| 国产原创中文字幕| 毛片的网站| 韩国三级香港三级日本三级| 成人av在线播放| 99色视频| 亚欧成人乱码一区二区| 精品视频在线观看免费| 亚洲第一页色| 精品久久久久久中文| 成人免费观看视频| 91麻豆国产福利精品| 免费一级片在线观看| 欧美a级大片| 久久成人综合网| 亚欧成人乱码一区二区| 精品视频在线观看免费| 久久99中文字幕久久| 韩国毛片基地| 国产国语在线播放视频| 成人高清视频在线观看|