成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

高性能WEB開發之JS、CSS的合并壓縮

開發 前端
本篇文章主要討論下目前JS,CSS 合并、壓縮、緩存管理存在的一些問題,然后分享下自己項目中用到的1個處理方案,并提供1個實例下載。

存在的問題:

合并、壓縮文件主要有2方面的問題:

1. 每次發布的時候需要運行一下自己寫的bat文件或者其他程序把文件按照自己的配置合并和壓縮。

2. 因生產環境和開發環境需要加載的文件不一樣,生產環境為了需要加載合并、壓縮后的文件,而開發環境為了修改、調試方便,需要加載非合并、壓縮的文件,所以我們常常需要在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> 

緩存問題:在現在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的引用代碼改成壓縮后并加了版本號的引用。

實例:

 

實例的文件結構如下圖:

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

看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. <% boolean isDev = false;  // 是否開發環境%> 
  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> 

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

實例下載:猛擊此處下載

系列文章:

高性能WEB開發之減少請求、響應的數據量

高性能WEB開發之如何減少請求數

高性能WEB開發之如何加載JavaScript

高性能WEB開發之圖片篇

高性能WEB開發之Web性能測試工具推薦

高性能WEB開發之HTTP服務器

責任編輯:陳貽新 來源: BearRui的博客
相關推薦

2011-04-27 10:57:29

高性能web開發

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-07 13:39:24

WebHTTP

2011-04-21 09:59:48

WEBjavascript

2013-09-10 16:16:19

移動網站性能優化移動web

2011-06-14 09:27:43

高性能WEB開發

2011-04-21 10:47:29

Webjavascript

2011-04-28 09:40:26

flush高性能Web開發

2011-04-25 10:11:57

高性能web開發

2016-08-23 14:37:21

2009-07-30 10:28:56

Web高性能開發

2013-08-16 14:43:14

高性能移動Web移動Web站點移動Web

2016-11-28 09:19:27

2013-06-19 09:20:53

Web開發Web性能優化高性能

2014-03-19 14:34:06

JQuery高性能

2013-09-10 17:13:57

移動網站性能優化移動web

2019-03-14 15:38:19

ReactJavascript前端
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 综合精品久久久 | 久久久久国产一级毛片 | 免费成人在线网站 | 玖玖玖在线观看 | 国产一在线 | 中文字幕爱爱视频 | 日韩成人 | 色天天综合 | 特黄色一级毛片 | 亚洲欧美另类在线观看 | 成人精品| 三级黄片毛片 | 亚洲精品视频一区 | 伊人色综合久久天天五月婷 | 久久夜色精品国产 | 国产一区二区三区不卡av | 欧美综合在线观看 | 精品视频在线免费观看 | 日韩区| 综合色影院| 天天拍天天色 | 亚洲一区二区三区视频免费观看 | 欧美激情一区二区三区 | 九九综合九九 | 免费影视在线观看 | 免费 视频 1级 | 91久久电影 | 一区二区三区不卡视频 | 91视频进入| 久久久一区二区三区 | 亚洲精品福利视频 | 日韩欧美在线视频 | 在线观看中文字幕视频 | 欧美日韩国产欧美 | 做a视频在线观看 | 亚洲精品国产一区 | 啪啪免费网站 | 久久精品中文字幕 | 日本精a在线观看 | 日本成人综合 | 亚洲bt 欧美bt 日本bt |