欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

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

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

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

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

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

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

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

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

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)目中的處理方案:

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

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

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

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《高性能WEB開(kāi)發(fā) JS、CSS的合并、壓縮、緩存管理》,本文關(guān)鍵詞  高性能,WEB,開(kāi)發(fā),CSS,的,合并,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《高性能WEB開(kāi)發(fā) JS、CSS的合并、壓縮、緩存管理》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于高性能WEB開(kāi)發(fā) JS、CSS的合并、壓縮、緩存管理的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    久久综合色一综合色88| 精品一二三四在线| 成人av动漫网站| 国产一二三四视频| 久久综合999| 久久97超碰国产精品超碰| 日本黄色片在线播放| 欧美精品久久天天躁| 一区av在线播放| 最新国产精品自拍| 欧美巨大另类极品videosbest| 亚洲精品免费在线观看| 91污在线观看| 欧洲av一区二区嗯嗯嗯啊| 一区二区三区资源| 91女人视频在线观看| 欧美在线不卡视频| 亚洲高清在线精品| 亚洲成人精品在线播放| 欧美高清一级片在线| 午夜成人免费电影| 黄色网址在线视频| 欧美va亚洲va在线观看蝴蝶网| 久久精品国产一区二区三区免费看| 亚洲欧美色图视频| 欧美精品一区二区三区久久久| 久久精品99国产精品日本| 久久久久亚洲av无码a片| 久久久久久久久岛国免费| 国精品**一区二区三区在线蜜桃| 5566中文字幕| 国产精品精品国产色婷婷| av电影天堂一区二区在线观看| 日本韩国一区二区三区视频| 一级特黄大欧美久久久| 男女一区二区三区| 欧美不卡一二三| 国产精一品亚洲二区在线视频| 日本二区三区视频| 亚洲精品日产精品乱码不卡| 国产极品一区二区| 久久综合国产精品| av中文字幕不卡| 777a∨成人精品桃花网| 老司机免费视频一区二区三区| www.日本高清视频| 亚洲欧美电影一区二区| 亚洲一区二区三区四区av| 精品日韩在线一区| 国产精品18久久久久久久网站| 日本韩国一区二区| 奇米色777欧美一区二区| www.日本高清视频| 一区二区三区视频在线看| av无码一区二区三区| 中文字幕不卡的av| 永久免费看片在线观看| 欧美mv日韩mv国产网站| 成人午夜视频在线| 欧美一区二区在线看| 国产精品99久久久久久久女警 | 免费黄色av网址| 日韩免费福利电影在线观看| 国产成人高清视频| 欧美日韩一区二区三区视频| 久久精品国产免费看久久精品| 日本一级特级毛片视频| 婷婷综合另类小说色区| 成人高潮免费视频| 天天色天天爱天天射综合| 欧美大片xxxx| 秋霞国产午夜精品免费视频 | 美脚の诱脚舐め脚责91| 国产精品99久久久久久成人| 日韩电影在线免费观看| 91人妻一区二区三区蜜臀| 日本一道高清亚洲日美韩| 黄色一级片中国| 免费观看30秒视频久久| 一本色道久久综合亚洲aⅴ蜜桃| 日韩av二区在线播放| 欧美三级在线免费观看| 久久99这里只有精品| 欧美三级电影在线观看| 国产乱码精品一区二区三区忘忧草| 欧美日韩国产在线观看| 国产成人综合在线| 日韩欧美国产小视频| 91浏览器打开| 国产精品久久久久久久久搜平片 | 蜜乳av中文字幕| 夜夜精品浪潮av一区二区三区| jizzjizzjizz国产| 亚洲一级二级三级在线免费观看| 日韩精品久久久久久久的张开腿让| 五月婷婷久久综合| 一本一道综合狠狠老| 国精产品一区一区三区mba桃花| 91精品国产综合久久久久久| 91在线一区二区三区| 国产精品免费久久| 国产sm调教视频| 日韩不卡一区二区三区| 欧美日韩国产美| 99久久精品99国产精品| 国产精品亲子伦对白| 亚洲AV无码成人精品区明星换面| 午夜精品一区在线观看| 欧美日韩在线播放三区| 成人黄色片在线观看| 国产农村妇女毛片精品久久麻豆| 欧美亚一区二区三区| 视频一区二区欧美| 欧美精品乱码久久久久久按摩| 久草福利在线观看| 亚洲婷婷在线视频| 9999热视频| 粉嫩久久99精品久久久久久夜| 久久久久久9999| 免费网站在线高清观看| 久久66热偷产精品| 精品99一区二区三区| 欧美丰满少妇人妻精品| 午夜视频在线观看一区二区三区| 欧美色综合网站| 日本黄色一级网站| 亚洲黄色小视频| 色综合婷婷久久| av色综合久久天堂av综合| ㊣最新国产の精品bt伙计久久| 免费中文字幕在线| 成人av在线影院| ...av二区三区久久精品| 色88888久久久久久影院按摩 | 亚洲乱码日产精品bd | 国产一区二区三区日韩| 久久综合成人精品亚洲另类欧美| 少妇久久久久久久久久| 久久不见久久见中文字幕免费| 少妇真人直播免费视频| 99久久99久久久精品齐齐| 中文字幕日韩精品一区| 三级影片在线看| 99久久精品国产一区二区三区| 亚洲欧美日本在线| 欧美午夜片在线看| 熟女人妻一区二区三区免费看 | 国产精品入口麻豆| 婷婷亚洲久悠悠色悠在线播放| 91精品国产综合久久精品麻豆 | 一区二区视频免费在线观看| 欧美日本乱大交xxxxx| 手机免费看av片| 男人操女人的视频在线观看欧美| 精品国产一区二区三区不卡 | 亚洲女与黑人做爰| 欧美性大战xxxxx久久久| 亚洲国产精品狼友在线观看| 日韩极品在线观看| 久久美女艺术照精彩视频福利播放| 国产免费嫩草影院| 波多野结衣中文字幕一区二区三区 | 欧美色图12p| 网站免费在线观看| 韩国欧美国产一区| 亚洲色图.com| 91精品国产欧美一区二区成人| a级在线观看视频| 国产福利一区在线| 一区二区三区在线免费视频| 欧美一级艳片视频免费观看| 中文字幕在线观看二区| 99免费精品视频| 青娱乐精品视频| 国产精品色噜噜| 欧美日本一道本| 我不卡一区二区| 99久久久无码国产精品| 天使萌一区二区三区免费观看| 国产亚洲短视频| 欧美体内she精高潮| www.色天使| 不卡视频在线看| 日本一区中文字幕| 中文字幕一区二区三区视频| 91精品国产综合久久久蜜臀粉嫩| 你懂得在线观看| 无码人妻精品一区二区三区99不卡| 精品综合免费视频观看| 亚洲男人的天堂一区二区| 欧美成人精品二区三区99精品| 国产精品九九九九九九| 黄色性生活一级片| www.亚洲精品| 久久国内精品视频| 一区二区三区在线观看动漫| 久久在线观看免费| 欧美日韩国产在线观看| 日本不卡一二区| 日韩人妻无码一区二区三区|