精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

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

開(kāi)發(fā) 前端
本篇文章主要討論下目前JS,CSS 合并、壓縮、緩存管理存在的一些問(wèn)題,然后分享下自己項(xiàng)目中用到的1個(gè)處理方案,并提供1個(gè)實(shí)例下載。

存在的問(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中類似與下面的判斷代碼:

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

緩存問(wèn)題:在現(xiàn)在JS滿天飛的時(shí)代,大家都知道緩存能帶來(lái)的巨大好處,但緩存確實(shí)非常麻煩的一個(gè)問(wèn)題,相信很多人曾經(jīng)歷過(guò)下面的情況:為了讓程序更快,在服務(wù)器上為JS加上緩沖5天的代碼,但產(chǎn)品更新后第二天就接到電話說(shuō)系統(tǒng)出錯(cuò),詳細(xì)了解后就發(fā)現(xiàn)是緩存引起的,讓用戶刪除緩存后就會(huì)OK。原因很簡(jiǎn)單,就是你JS已經(jīng)修改了,但用戶還在使用緩存中的老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)如下圖:

JS、CSS的合并、壓縮、緩存管理

看JSP原始代碼(程序運(yùn)行前):

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

程序運(yùn)行后JSP的代碼:

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

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

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

系列文章:

高性能WEB開(kāi)發(fā)之減少請(qǐng)求、響應(yīng)的數(shù)據(jù)量

高性能WEB開(kāi)發(fā)之如何減少請(qǐng)求數(shù)

高性能WEB開(kāi)發(fā)之如何加載JavaScript

高性能WEB開(kāi)發(fā)之圖片篇

高性能WEB開(kāi)發(fā)之Web性能測(cè)試工具推薦

高性能WEB開(kāi)發(fā)之HTTP服務(wù)器

責(zé)任編輯:陳貽新 來(lái)源: BearRui的博客
相關(guān)推薦

2011-04-27 10:57:29

高性能web開(kāi)發(fā)

2011-04-18 10:16:30

WEB高性能

2011-04-07 13:53:25

Web工具

2011-04-19 11:06:03

JavaScriptweb

2011-10-18 13:58:32

高性能web

2011-04-21 09:59:48

WEBjavascript

2011-04-07 13:39:24

WebHTTP

2013-09-10 16:16:19

移動(dòng)網(wǎng)站性能優(yōu)化移動(dòng)web

2011-06-14 09:27:43

高性能WEB開(kāi)發(fā)

2011-04-21 10:47:29

Webjavascript

2011-04-25 10:11:57

高性能web開(kāi)發(fā)

2011-04-28 09:40:26

flush高性能Web開(kāi)發(fā)

2009-07-30 10:28:56

Web高性能開(kāi)發(fā)

2016-08-23 14:37:21

2016-11-28 09:19:27

2013-06-19 09:20:53

Web開(kāi)發(fā)Web性能優(yōu)化高性能

2013-08-16 14:43:14

高性能移動(dòng)Web移動(dòng)Web站點(diǎn)移動(dòng)Web

2013-09-10 17:13:57

移動(dòng)網(wǎng)站性能優(yōu)化移動(dòng)web

2014-03-19 14:34:06

JQuery高性能

2019-03-14 15:38:19

ReactJavascript前端
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

在线观看日韩毛片| 日韩电影免费观看高清完整版在线观看| 国产美女主播视频一区| 久久99热精品这里久久精品| 人妖粗暴刺激videos呻吟| 麻豆理论在线观看| 国产欧美日韩在线看| 91九色视频导航| 日本少妇bbwbbw精品| 免费一区二区三区视频导航| 欧洲国内综合视频| 久久国产精品免费观看| 日韩私人影院| 激情另类小说区图片区视频区| 欧美激情影音先锋| 亚洲精品国产精品国自| 91麻豆精品激情在线观看最新| 欧美日韩亚洲一区二区三区| 一区精品视频| 色鬼7777久久| 国产一区二区精品久久91| 欧美性做爰毛片| 国产精品免费人成网站酒店| 伊人久久大香线蕉无限次| 欧美精品久久99| 久久久精品在线视频| 国产精品一卡二卡三卡| 久久久亚洲精品石原莉奈| 91传媒视频免费| 日韩黄色一级视频| 精品动漫av| 久久精品最新地址| 国产成人精品无码免费看夜聊软件| 成人51免费| 欧洲一区在线电影| 国产在线青青草| 午夜伦理在线视频| 国产精品国产三级国产三级人妇| 久久伊人一区二区| 欧美 中文字幕| 国产成人自拍网| 成人性生交大片免费看小说| 波多野结衣在线观看一区| 一区二区高清| 国语自产偷拍精品视频偷 | gogo大胆日本视频一区| 92国产精品久久久久首页 | 蓝色福利精品导航| 国产v综合ⅴ日韩v欧美大片| 日本视频免费在线| 亚洲成人资源| 久久久亚洲影院| 欧美日韩人妻精品一区二区三区| 日韩在线综合| 视频一区视频二区国产精品| 五月激情四射婷婷| 成人91在线| 深夜福利91大全| 精品少妇一区二区三区密爱| 欧美黄色录像片| 中文日韩在线视频| 欧美人与禽zoz0善交| 成人精品视频| 日韩中文在线观看| 久久国产波多野结衣| 91一区二区| 久久精品2019中文字幕| www.97视频| 欧美va天堂在线| 久久久噜久噜久久综合| 精品成人久久久| 天堂久久久久va久久久久| 日韩av不卡电影| 国产黄色免费视频| 美女视频网站黄色亚洲| 91精品视频免费看| 亚洲精品国产一区二| 波多野结衣中文字幕一区| 精品欧美一区二区精品久久| 毛片网站在线| 国产精品成人在线观看| 91看片淫黄大片91| 女厕盗摄一区二区三区| 日本精品视频一区二区| 91女神在线观看| 亚洲精品视频一二三区| 日韩精品在线影院| 五月婷六月丁香| 亚洲午夜精品一区二区国产| 久久免费视频在线观看| 久久精品久久久久久久| 久久草av在线| 成人区精品一区二区| 女人偷人在线视频| 国产精品三级电影| 特级西西人体www高清大胆| 国产在线美女| 欧美日韩免费不卡视频一区二区三区 | 电影在线观看一区| 欧美最猛性xxxxx直播| 久久6免费视频| 欧美三级午夜理伦三级小说| 中文字幕亚洲综合久久| 久久综合成人网| 丝袜诱惑亚洲看片| www日韩av| 成人性生交大片免费看午夜 | 国产精品久久久久久99| 久久国产欧美日韩精品| 国产综合18久久久久久| 91在线直播| 精品久久久精品| 91成人免费视频| 中文字幕视频在线免费观看| 伊人久久大香伊蕉在人线观看热v| 日韩天堂在线观看| 在线不卡av电影| 国产一区欧美| 国产欧美精品va在线观看| 亚洲精品综合网| 亚洲国产岛国毛片在线| 欧美 丝袜 自拍 制服 另类 | 国产综合福利在线| 色视频免费在线观看| 亚洲精品写真福利| 欧美一级特黄a| 五月国产精品| 高清视频欧美一级| 国产又爽又黄免费软件| 久久精品一区二区| 久久国产精品视频在线观看| 国产一区 二区| 在线观看欧美视频| 成年人av网站| 久久婷婷国产综合国色天香 | 欧洲性xxxx| 性一交一乱一区二区洋洋av| 99免费在线观看视频| 日本在线免费中文字幕| 色老汉av一区二区三区| 成人免费毛片日本片视频| 欧美日韩第一区| 91社区国产高清| a√资源在线| 欧洲人成人精品| 香蕉视频久久久| 久久精品电影| 久久免费看av| 自拍视频在线看| 亚洲精品久久久久久久久| 久久久久久久久久久久久久免费看 | 性色av蜜臀av| 亚洲精品一二三四区| 国产成人美女视频| 久久国产小视频| 国产免费一区二区三区在线能观看 | 艳母动漫在线免费观看| 在线高清欧美| 久久av.com| www.国产麻豆| 亚洲h精品动漫在线观看| 91精品啪在线观看国产| 一区二区亚洲| 精品蜜桃传媒| 久久99久久99精品免观看软件| 亚洲精品一二区| 中文字幕日韩免费| 欧美国产一区在线| 手机av在线免费| 综合久久久久| 狠狠色伊人亚洲综合网站色| 老色鬼在线视频| 亚洲色图25p| 一本色道久久综合熟妇| 亚洲乱码国产乱码精品精的特点| wwwww在线观看| 一本色道久久精品| 日韩久久久久久久| 亚洲欧美在线人成swag| 欧美激情高清视频| 性xxxxbbbb| 欧美综合久久久| 日韩va亚洲va欧美va清高| 粉嫩久久99精品久久久久久夜 | 涩涩视频在线| 在线精品国产成人综合| 国产免费一区二区三区最新不卡| 亚洲一区二区视频在线观看| 久久精品女同亚洲女同13| 爽好多水快深点欧美视频| 日本福利视频导航| 国产露脸无套对白在线播放| 中文字幕欧美一| 色婷婷精品久久二区二区密| 蜜桃一区二区三区四区| 久久久水蜜桃| 久久久久久久久久久久电影| 91精品国产91综合久久蜜臀| 深夜福利影院在线观看| 99精品久久久久久| 中日韩av在线播放| 蜜桃久久久久| 日本韩国欧美精品大片卡二| av网址在线| 一区二区三区日韩欧美| 欧美日韩另类一区| 亚洲国产无码精品| 久久99这里只有精品| 热门国产精品亚洲第一区在线| 毛片网站在线免费观看| 亚洲女成人图区| 免费91在线观看| 久久电影网电视剧免费观看| 日韩a级在线观看| 少女频道在线观看免费播放电视剧| 亚洲男人天堂网| 丰满肉肉bbwwbbww| 26uuu国产日韩综合| 在线免费视频a| 99精品视频免费观看| 黄色高清视频网站| 黑人极品ⅴideos精品欧美棵| 日韩国产精品视频| 亚洲精品喷潮一区二区三区| 久久综合九色综合97婷婷女人| 一级黄色录像在线观看| 青青久久精品| 国产精品视频一区国模私拍 | 国产精品美女xx| 精品99又大又爽又硬少妇毛片| 中文字幕日韩一区| 91视频免费看片| 伊人影院久久| 久久一区二区三区av| 福利片在线一区二区| 亚洲精品一区二区三区婷婷月| 国产字幕在线观看| 色三级在线观看| 欧美一区二区日韩| 91在线观看喷潮| 中文字幕一区二区三区视频| 欧美性猛交xxxx乱大交91| 蜜桃视频在线观看一区二区| 精品欧美国产一区二区三区不卡| 日韩大尺度黄色| 色偷偷av亚洲男人的天堂| 国产又粗又长又黄的视频| 国产日韩欧美| 国产二区视频在线| 神马电影网我不卡| 欧美一区二区三区四区五区| 亚洲免费黄色网址| 国产一区二区调教| 91xxx视频| 肉色欧美久久久久久久免费看| 欧美视频在线观看免费| 青青草精品在线| 成人性生交大片免费看网站| 精品国产乱码久久久久久浪潮| 亚洲色图第四色| 亚洲欧美综合| 91po在线观看91精品国产性色| 一区二区三区播放| 久久久成人网| 欧美日韩电影在线观看| www.久久网| 欧美午夜理伦三级在线观看| 91久久国语露脸精品国产高跟| 欧美日韩一区小说| 欧美xxxx日本和非洲| 国产特黄级aaaaa片免| 日韩国产在线观看一区| 免费在线观看毛片网站| 天天久久夜夜| 亚洲国产日韩综合一区| 成人激情开心网| 日韩免费毛片| 亚洲成人tv| 久久久天堂国产精品| 欧美精品日韩| 欧美爱爱视频免费看| 国产毛片久久| 成人性生生活性生交12| 国产自产v一区二区三区c| 红桃视频一区二区三区免费| 国产91在线观看| 美女爆乳18禁www久久久久久| 国产精品污网站| 欧美成人三级视频| 色8久久人人97超碰香蕉987| 亚洲天堂手机在线| 日韩一区二区在线观看视频播放| 日本激情一区二区| 亚洲色图欧美制服丝袜另类第一页| 伊人免费在线| 午夜精品理论片| 99精品国自产在线| 99国精产品一二二线| 精品99久久| 肉大捧一出免费观看网站在线播放 | 精品国产乱码久久久久久108| 亚洲天堂日韩在线| 伊人久久大香线蕉成人综合网| 99成人精品| 久久这里只精品| 成人免费视频网站在线观看| www.xx日本| 精品国产福利视频| 一区二区三区播放| 国产丝袜精品第一页| 日韩在线资源| 2021国产精品视频| 一区二区日韩| 亚洲精品在线观看免费| 欧美成熟视频| 国产三级国产精品国产专区50| 国产91精品久久久久久久网曝门| 97超碰在线资源| 亚洲成人久久影院| 97人妻人人澡人人爽人人精品| 欧美一区二区三区视频| 黄色的视频在线免费观看| 欧美日韩999| 视频91a欧美| 欧美日本国产精品| 精品白丝av| 国产一卡二卡三卡四卡| 国产精品福利一区| 亚洲免费在线视频观看| 亚洲第一精品电影| 免费网站免费进入在线| 91国内精品久久| 黄色成人美女网站| 第九区2中文字幕| 青青草97国产精品免费观看无弹窗版 | 51精品秘密在线观看| 国产69精品久久app免费版| 清纯唯美亚洲激情| 国产精品白浆| 特级西西444| 国产成人午夜99999| 伊人久久久久久久久久久久久久| 欧美丝袜一区二区| 天天射天天操天天干| 另类视频在线观看| a一区二区三区| 欧美日韩精品免费观看| 国产精品日韩久久久| 国产三级视频网站| 亚洲成人精品在线观看| 亚洲乱熟女一区二区| 久久久久久亚洲精品不卡| 欧美中文高清| 粉嫩av一区二区三区天美传媒| 国产一区二区三区四区五区入口| 国产精品综合激情| 欧美精品在线一区二区三区| 自拍视频在线免费观看| 国产精品美女999| 91精品国产91久久综合| 久久久久久久久久久久久久久国产| 国产精品午夜免费| 国产日韩欧美一区二区东京热| www.日韩.com| 日韩欧乱色一区二区三区在线| 青青草原网站在线观看| 国产在线视视频有精品| 欧美日韩国产精品综合| 欧美精品一区二区在线观看| 久久99亚洲网美利坚合众国| 精品国产电影| 欧美亚洲一级| 一级肉体全黄裸片| 欧洲av一区二区嗯嗯嗯啊| 在线看的av网站| 91视频网页| 亚洲精品少妇| 加勒比一区二区| 欧美色男人天堂| 日韩伦理在线电影| 国产精品一国产精品最新章节| 激情视频一区| b站大片免费直播| 5566中文字幕一区二区电影| 91精品久久| 欧美精品一区在线| 三级在线观看一区二区| 97成人资源站| 亚洲国产精品久久久久| www.com.cn成人| 三上悠亚免费在线观看| 99久久婷婷国产| 中文字幕视频免费观看| 久久这里只有精品视频首页| aaa国产精品| 亚洲视频第二页| 亚洲成人1区2区| melody高清在线观看| 国产欧美一区二区视频| 天堂成人国产精品一区|