前端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? ,如需轉載請自行聯系原作者


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/454378.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/454378.shtml
英文地址,請注明出處:http://en.pswp.cn/news/454378.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

我們的系統檢測到您的計算機網絡中存在異常流量_如何建立我們的網絡防線?入侵檢測,確保我們的網絡安全...

目前我們的網絡安全趨勢日益嚴峻,那么如何利用入侵檢測系統確保我的網絡安全呢?入侵檢測又是什么呢?網絡安全入侵檢測技術是為保證計算機系統的安全,而設計與配置的一種能夠及時發現并報告系統中未授權或異常現象的技術&#xff0…

sql修改鏈接服務器名稱,SQL Server 創建鏈接服務器的腳本,自定義鏈路服務器的簡短名稱...

USE [master]GO/****** Object: LinkedServer [SQL01] Script Date: 2020/4/9 11:51:17 ******/EXEC master.dbo.sp_addlinkedserver server N‘SQL01‘, srvproductN‘‘, providerN‘SQLNCLI‘, datasrcN‘域名或者IP‘/* For security reasons the linked server remot…

mybatis $和#源代碼分析

JDBC中,主要使用兩種語句,一種是支持參數化和預編譯的PreparedStatement,支持原生sql,支持設置占位符,參數化輸入的參數,防止sql注入攻擊,在mybatis的mapper配置文件中,我們通過使用#和$告訴mybatis我們需要…

git 命令詳解和常見問題解決

功能一 提交:1:git init # 初始化,表示即將對當前文件夾進行版本控制2:git status # 查看Git當前狀態,如:那些文件被修改過、那些文件還未提交到版本庫等。3:git add . # 添加當前目錄下所有文件到版本…

辭職日記----記錄31歲的程序員跳槽心態

vcleaner http://topic.csdn.net/u/20080626/23/8f6a8ecc-c072-43ee-bf2d-7ac2286b6805.html http://topic.csdn.net/u/20080704/23/858fc00d-ec14-4db7-93be-34903b7f157a.html 轉載他的離職日記,有許多東西值得我們認真思考,人活著到底為了什么&a…

從Android源碼的角度分析Binder機制

IPC 為了弄懂IPC的來龍去脈,我將從以下三個方面為大家來講解,希望對大家理解IPC會有幫助 什么是IPC IPC是Inter Process Communication的縮寫,其意思就是進程間的通信,也就是兩個進程之間的通信過程。我們都知道在Android系統中&a…

excel vba 調用webbrowser_VBA 公式與函數

一, 在單元格中輸入公式的3種方法:1) 用VBA在單元格中輸入普通公式Sub formula_1() Range("d2") ("B2 * C2") End Sub運行程序后,在D2的單元格內顯示的是公式 B2 * C2 ,并非程序返回值.下文(二)中會介紹另外一種直接返回值的方式想要通過程序一…

內部類可以引用它的包含類的成員嗎?有沒有什么限制?

最近看到一道面試題:內部類可以引用它的包含類的成員嗎?有沒有什么限制? 答案大部分都是這樣子的: 完全可以。如果不是靜態內部類,那沒有什么限制! 一個內部類對象可以訪問創建它的外部類對象的成員包括私有…

松下NPM服務器怎么備份系統,松下(Panasonic)-NPM校正amp;CPK完整版教程,一步步帶你成為SMT設備大神!...

馬上注冊,結交更多技術專家,享用更多功能,讓你輕松解決各種三星貼片機問題您需要 登錄 才可以下載或查看,沒有帳號?立即注冊 xa8f80375060fa05b8aebe69ffa21080c.gif (5.26 KB, 下載次數: 3)2019-8-12 00:02 上傳f5aae…

Python 模塊之科學計算 Pandas

目錄 一、Pandas簡介 數據結構 二、Series series 的創建 Series值的獲取 Series的運算 Series缺失值檢測 Series自動對齊 Series及其索引的name屬性 三、DataFrame 創建 Index對象 通過索引值或索引標簽獲取數據 自動化對齊 四、文件操作 文件讀取 數據庫數據…

根據 設備名(br0/eth0/em0)稱獲取 當前機器的IP地址與子網掩碼信息

#!/usr/bin/env python 根據 設備名(br0/eth0/em0)稱獲取 當前機器的IP地址與子網掩碼信息import socket, struct, fcntldef get_ipaddress(ifname eth0):s socket.socket(socket.AF_INET, socket.SOCK_DGRAM)return socket.inet_ntoa(fcntl.ioctl(s.fileno(),0x8915, # SI…

我的程序生涯

本文僅為愛好程序及向往真正之程序員者所作,其余人等可忽略下文。 如今,接觸CS幾近八年,不學無術,所精之物鮮也,以至一事無成。 現回憶吾程序之生涯,以整理繁雜之心緒。 1. 接觸計算機和編程語言 02年始大…

機器學習中qa測試_如何對機器學習做單元測試

作者:Chase Roberts編譯:ronghuaiyang導讀養成良好的單元測試的習慣,真的是受益終身的,特別是機器學習代碼,有些bug真不是看看就能看出來的。在過去的一年里,我把大部分的工作時間都花在了深度學習研究和實…

項目寶提供的服務器,開源WebSocket服務器項目寶貝魚CshBBrain V4.0.1 和 V2.0.2發布

開源WebSocket服務器項目寶貝魚CshBBrain V4.0.1 和 V2.0.2發布更新的功能列表如下:1.解決開啟廣播消息開關時,不能同時接入2個客戶端的重大缺陷。2.對廣播消息做了重大優化,從以前一個線程發送廣播消息進化到使用工作線程池中的線程并行的發…

c# 無損高質量壓縮圖片代碼

/// 無損壓縮圖片 /// <param name"sFile">原圖片</param> /// <param name"dFile">壓縮后保存位置</param> /// <param name"dHeight">高度</param> /// <param name"dWidth"…

一個從文本文件里“查找并替換”的功能

12345678910111213141516171819202122232425# -*- coding: UTF-8 -*-file input("請輸入文件路徑:") word1 input("請輸入要替換的詞:") word2 input("請輸入新的詞&#xff1a;") fopen(file,"r") AAAf.read() count 0 def BBB()…

機器學習算法之 KNN

K近鄰法(k-nearst neighbors,KNN)是一種很基本的機器學習方法了&#xff0c;在我們平常的生活中也會不自主的應用。比如&#xff0c;我們判斷一個人的人品&#xff0c;只需要觀察他來往最密切的幾個人的人品好壞就可以得出了。這里就運用了KNN的思想。KNN方法既可以做分類&…

安裝云端服務器操作系統,安裝云端服務器操作系統

安裝云端服務器操作系統 內容精選換一換SAP云服務器規格在申請SAP ECS之前&#xff0c;請參考SAP標準Sizing方法進行SAPS值評估&#xff0c;并根據Sizing結果申請云端ECS服務器資源&#xff0c;詳細信息請參考SAP Quick Sizer。SAP 各組件最低硬盤空間、RAM&#xff0c;以及軟件…

python 進度條_六種酷炫Python運行進度條

轉自&#xff1a;一行數據閱讀文本大概需要 3 分鐘你的代碼進度還剩多少&#xff1f;今天給大家介紹下目前6種比較常用的進度條&#xff0c;讓大家都能直觀地看到腳本運行最新的進展情況。1.普通進度條2.帶時間進度條3.tpdm進度條4.progress進度條5.alive_progress進度條6.可視…

js 獲取多少天前

getBeforeDate: function(day, str) { var now new Date().getTime(); //獲取毫秒數 var before new Date(now - ((day > 0 && day ? day : 0) * 86400 * 1000)); var year before.getFullYear(); var month before.getMonth()1; var date before.getDate(); …