婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

熱門標簽:忻州外呼系統接口對接 語音平臺系統 醫院地圖標注 嘟聲的電銷機器人 洛陽便宜外呼系統廠家 湖北穩定外呼系統 地圖標注和圖片標注 電銷機器人怎么收費 滄州智能外呼系統收費
存在的問題:

合并、壓縮文件主要有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中的版本號來控制緩存,這個是最嚴謹的一個方法,但也因為做起來太復雜,所以一直也沒做起來,以后以后有時間可以再研究。
您可能感興趣的文章:
  • CSS3 動畫卡頓性能優化的完美解決方案
  • js中用事實證明cssText性能高的問題
  • 微信小程序 扭蛋抽獎機css3動畫實現詳解
  • vue操作動畫的記錄animate.css實例代碼
  • Vue中CSS動畫原理的實現
  • 原生JS檢測CSS3動畫是否結束的方法詳解
  • 微信小程序CSS3動畫下拉菜單效果
  • 詳解盒子端CSS動畫性能提升

標簽:防城港 定州 巴彥淖爾 內蒙古 96 日照 宜賓 山南

巨人網絡通訊聲明:本文標題《高性能WEB開發 JS、CSS的合并、壓縮、緩存管理》,本文關鍵詞  高性能,WEB,開發,CSS,的,合并,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《高性能WEB開發 JS、CSS的合并、壓縮、緩存管理》相關的同類信息!
  • 本頁收集關于高性能WEB開發 JS、CSS的合并、壓縮、緩存管理的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲国产美女搞黄色| 欧美精品一区视频| 成人丝袜18视频在线观看| 中文字幕一区免费在线观看| 中文字幕成人在线观看| 国产精品电影院| 欧美一级爆毛片| 国内久久婷婷综合| 欧美性三三影院| 日韩成人精品视频| 亚洲欧美经典视频| 国产天堂亚洲国产碰碰| 成人丝袜18视频在线观看| 在线观看国产一区二区| 午夜伦欧美伦电影理论片| 亚洲图片欧美综合| 欧美视频日韩视频在线观看| 国产午夜精品福利| 欧美日韩精品一区二区三区蜜桃| 欧美三级乱人伦电影| 日韩免费看的电影| 在线不卡一区二区| 日韩美女精品在线| 亚洲综合激情网| 欧美精品一区二区三区久久久| 国产欧美一区视频| 国产精品自在欧美一区| 美女免费视频一区二区| 国产高清精品在线| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美视频日韩视频在线观看| 国产精品嫩草影院com| 国产精品天天看| 91网址在线看| 国产拍揄自揄精品视频麻豆| 亚洲精品五月天| 日本vs亚洲vs韩国一区三区| 亚洲精品在线三区| 粉嫩av一区二区三区| 91精品国产综合久久久久久久久久 | 久久先锋影音av| 久草这里只有精品视频| 日韩一区二区精品在线观看| 精品亚洲成av人在线观看| 国产精品一区免费在线观看| 一区二区三区毛片| 一区二区三区在线免费播放| 中文字幕在线观看一区| 国产精品视频一二三区| 极品销魂美女一区二区三区| 久久久久高清精品| 欧美精品国产精品| 国产精品一卡二卡在线观看| 日产国产欧美视频一区精品| 久久久久久久国产精品影院| 欧美色男人天堂| 激情亚洲综合在线| 欧美一二三四在线| 一本大道久久a久久综合婷婷| 亚洲国产精品成人综合色在线婷婷 | 亚洲精品视频在线| 欧美一级日韩不卡播放免费| 成人高清视频免费观看| 日本一区中文字幕| 久久久久亚洲蜜桃| 欧美剧情片在线观看| 国产一区二区剧情av在线| 亚洲靠逼com| 国产欧美一区二区精品忘忧草| 日本高清成人免费播放| 99精品一区二区| 不卡视频在线观看| 日韩欧美www| 日本美女一区二区| 天天av天天翘天天综合网色鬼国产| 爽好久久久欧美精品| 裸体一区二区三区| 久久精品人人做人人爽97| 91在线你懂得| 91亚洲国产成人精品一区二区三| 亚洲v精品v日韩v欧美v专区| 亚洲综合视频网| 国产精品欧美一区二区三区| 国产视频一区不卡| 欧美一区二区三区系列电影| 日韩欧美在线不卡| 久久蜜臀中文字幕| 久久精品网站免费观看| 亚洲国产精品成人综合| 国产三级三级三级精品8ⅰ区| 91精品国产欧美一区二区| 日韩亚洲电影在线| 久久精品免费在线观看| 久久精品日韩一区二区三区| 综合欧美亚洲日本| 午夜婷婷国产麻豆精品| 日韩专区欧美专区| 日本成人中文字幕| 精品一区二区影视| 国产黑丝在线一区二区三区| 97久久久精品综合88久久| 午夜电影久久久| 日韩一级成人av| 精品1区2区在线观看| 色欧美片视频在线观看在线视频| 91精品久久久久久久99蜜桃| 中文字幕成人网| 欧美mv日韩mv国产| 艳妇臀荡乳欲伦亚洲一区| 日韩亚洲欧美一区| 亚洲天堂中文字幕| 国产日韩欧美综合一区| 激情文学综合插| 激情欧美一区二区| 国产99一区视频免费| 波波电影院一区二区三区| 91麻豆精品国产91久久久资源速度 | 樱花影视一区二区| 亚洲精品美国一| 国产成人午夜高潮毛片| 97se亚洲国产综合在线| 国产精品一区二区x88av| 色婷婷av久久久久久久| 国产午夜精品久久| 一区二区在线观看不卡| 91免费视频大全| 欧美中文字幕一区| 欧美日本国产视频| 天天色综合天天| 欧美在线小视频| 国产精品久久一级| 日韩一区二区麻豆国产| 国产一区二区三区不卡在线观看 | 美国一区二区三区在线播放| 4438x成人网最大色成网站| 777久久久精品| 美腿丝袜亚洲综合| 亚洲欧美另类久久久精品2019| 免费看日韩a级影片| 国产视频一区在线播放| 综合亚洲深深色噜噜狠狠网站| 精品免费视频.| 亚洲国产综合色| 在线播放/欧美激情| 亚洲欧美乱综合| 美腿丝袜亚洲一区| 亚洲国产精品av| 日本二三区不卡| 韩国欧美国产一区| 一区在线播放视频| 欧美性猛交xxxx黑人交| 美女任你摸久久| 国产夫妻精品视频| 337p亚洲精品色噜噜狠狠| 在线欧美一区二区| 91精品国产福利在线观看| 不卡的av中国片| 国产精品色哟哟网站| 日韩视频在线观看一区二区| 国产成人免费视频网站高清观看视频 | 国产精品福利一区二区三区| 在线播放国产精品二区一二区四区| 91欧美激情一区二区三区成人| www.欧美.com| 精品一区二区三区久久久| 亚洲欧美激情在线| 国产91富婆露脸刺激对白| 激情成人午夜视频| 亚洲欧洲美洲综合色网| 久久久久久久久伊人| 欧美大度的电影原声| 亚洲最新在线观看| 精品美女在线播放| 色天使久久综合网天天| 久久夜色精品国产欧美乱极品| 99re亚洲国产精品| 五月激情综合色| 91久久精品网| 香蕉乱码成人久久天堂爱免费| 欧美精品一区二区三区蜜桃| 久久色视频免费观看| 欧美猛男男办公室激情| 日本丶国产丶欧美色综合| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲一区在线播放| 国产精品第一页第二页第三页| 久久久99免费| 韩国欧美国产1区| 日本成人在线看| 麻豆精品新av中文字幕| 亚洲国产精品久久一线不卡| 日韩电影免费在线| 91国偷自产一区二区开放时间 | 欧美一区二区视频免费观看| 91极品美女在线| av不卡一区二区三区| 成人激情免费视频| 美女www一区二区| 国产69精品久久久久毛片| 亚洲国产精品天堂|