中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JS與CSS的合并壓縮如何實現

發布時間:2023-01-11 09:38:23 來源:億速云 閱讀:117 作者:iii 欄目:開發技術

本篇內容介紹了“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>

緩存問題:

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原始代碼(程序運行前):

<%@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>         <h2 class="c1">Hello World!</h2>     </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>         <h2 class="c1">Hello World!</h2>     </body> </html>

加3gmin后綴的文件全部是程序啟動時自動生成的。

“JS與CSS的合并壓縮如何實現”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

马关县| 江安县| 山西省| 阿克苏市| 平南县| 化州市| 甘德县| 墨江| 武清区| 集安市| 确山县| 定南县| 麻城市| 抚顺市| 永州市| 桂林市| 松江区| 杨浦区| 临安市| 山阳县| 顺义区| 泸水县| 太保市| 西青区| 太仓市| 天等县| 静宁县| 鱼台县| 白山市| 长海县| 杭锦后旗| 鄱阳县| 湘乡市| 平顶山市| 博罗县| 龙岩市| 广平县| 房山区| 武胜县| 舟山市| 庆安县|