日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

前端js文件合并三种方式

發布時間:2023/12/19 HTML 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 前端js文件合并三种方式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

最近在思考前端js文件該如何合并,當然不包括不能合并文件,而是我們能合并的文件,想了想應該也只有三種方式。

三個方式如下:

1.?一個大文件,所有js合并成一個大文件,所有頁面都引用它。

2.?各個頁面大文件,各自頁面合并生成自己所需js的大文件。

3.?合并多個共用大文件,根據實踐情況合并出多個共用js文件,每個頁面引用多個共用大文件。

另外在我看來,合并有兩個目的:

1. 為了減少請求數。

2. 代碼安全考慮(文件分得越多,越容易被人看清)。

PS:注意我說的不是壓縮混淆,只是合并

1. 一個大文件

這種方式就是不管三七二十一,所有js合并成一個大文件,所有頁面都引用它,即使某些代碼可能不會用到。

優點:

(1). 合并簡單,使用也簡單。

(2). 其他頁面可利用緩存優化加載。

缺點:

(1). 頁面可能會加載到本頁面不使用的代碼。

不適用場景:

(1). 這種方式肯定不適用于大型的Web應用,且不論單文件代碼量,業務的復雜性也不允許我們這樣干(我沒見過那個網站這樣做的)。

適用場景:

(1). Hybrid應用,無論是Mobile的Hybrid應用,還是PC的Hybrid應用(桌面應用,類似有道團隊開發框架hex+chromium +nodejs),都非常適合,本身就不會有請求速度問題,這種位于客戶端代碼的應用的代碼安全更為重要。

PS:當然最重要的還是后端的安全,無論前端是否被破解,后端是否完善輸入校驗,是否防止越權,后端才是關鍵,也就是常說一句話“不要相信用戶的任何輸入”。

2. 各個頁面大文件

各個頁面合并生成自己所需js的大文件,生成多份js合并。

優點:

(1). 每個頁面都用到最精確的js,不會有不相關代碼。

缺點:

(1). 有多少個頁面,就會生成多個js,導致存在大量共同js代碼的冗余。

(2). 共用部分無法使用緩存優化加載。

(3). 合并和使用會相對比較復雜。

這種方式我始終覺得不對勁,小應用直接單個大文件搞定,而大應用更不會這樣去做,更不能用在Hybrid應用上,在這樣講究安裝包大小的情形下,不能容忍冗余代碼。我在思考各種場景時候,都發現能用上面或下面方式解決,而且是更優,所以我覺得這種方式是個雞肋。

3. 合并多個共用大文件

根據實踐情況合并多個共用大文件(例如依賴庫分類),再合并本頁面所需js文件(例如以業務分類),每個頁面引用一個或多個共用大文件和本頁面的js文件。

優點:

(1). 共用部分得到加載優化,每個頁面引用的也盡可能的做到了不冗余。

缺點:

(1). 多多少少還是會存在某些頁面會引用到不需要的代碼,共用不并不是完完全全的共用。

適用場景:

(1). 大小型應用都比較適用,每個頁面可能存在許多共用部分,合理的分文件合并將非常關鍵。

總結

這一篇文件只是思考,也只算泛泛之談。文件合并方法挺多,由后端動態生成或工具直接生成(grunt+requirejs),合并的方式也就以上三種,也取決于我們實踐需要。

合并很重要,但不是提倡所有文件都合并起來,有不能合并的,有些單獨文件更優的,還是要看具體場景。

?

本文為原創文章,轉載請保留原出處,方便溯源,如有錯誤地方,謝謝指正。

本文地址 :http://www.cnblogs.com/lovesong/p/5068025.html


本文轉自 海角在眼前 博客園博客,原文鏈接:?http://www.cnblogs.com/lovesong/p/5068025.html? ,如需轉載請自行聯系原作者


創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的前端js文件合并三种方式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。