<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        前端構建大法Gulp系列(一):為什么需要前端構建_html/css_WEB-ITnose

        來源:懂視網 責編:小采 時間:2020-11-27 16:35:44
        文檔

        前端構建大法Gulp系列(一):為什么需要前端構建_html/css_WEB-ITnose

        前端構建大法Gulp系列(一):為什么需要前端構建_html/css_WEB-ITnose:我們都知道使用IDE編寫后端程序時,我們都需要Build, 對.NET來說,我們一般需要使用Visual Studio來確保我們的項目編譯通過,而且項目編譯通過是對所有程序員的基本要求。 但是,由于很多后端程序員對前端的很多東西不了解,導致在做WEB項目時出現了一些問
        推薦度:
        導讀前端構建大法Gulp系列(一):為什么需要前端構建_html/css_WEB-ITnose:我們都知道使用IDE編寫后端程序時,我們都需要Build, 對.NET來說,我們一般需要使用Visual Studio來確保我們的項目編譯通過,而且項目編譯通過是對所有程序員的基本要求。 但是,由于很多后端程序員對前端的很多東西不了解,導致在做WEB項目時出現了一些問

        我們都知道使用IDE編寫后端程序時,我們都需要Build, 對.NET來說,我們一般需要使用Visual Studio來確保我們的項目編譯通過,而且項目編譯通過是對所有程序員的基本要求。

        但是,由于很多后端程序員對前端的很多東西不了解,導致在做WEB項目時出現了一些問題。

        JavaScript和CSS的版本問題

        我們都知道 JavaScript和CSS屬于靜態文件,如果地址不變,瀏覽器會緩存這些文件,那就意味著當我們需要改JavaScript或者CSS文件的時候,即使我們后端改了,那么客戶端也是看不到,這個在“JS一統天下”的時代是不可接受的,因為現在幾乎所有的WEB 程序都嚴重依賴JavaScript,而所有的網站都是需要使用CSS的。在我經歷過的項目即使是很多年經驗的程序員都出現過JavaScript和CSS文件的版本問題,比如客戶讓修復一個Bug,這個Bug是JavaScript引起的,程序員修復了,或者是客戶說改一個背景顏色, 可是當我們給客戶部署后或者代碼交給客戶客戶部署時,客戶說Bug依然存在,這個時候程序員經常說的話就會出現了 “我本地是好的呀”,最后再找來別人幫忙后,發現原來是沒有清除瀏覽器的緩存,于是有的程序員就趕緊給客戶說:“你需要Ctrl+F5 清除瀏覽器的緩存”。 每當我聽到這樣的話時就像關上燈留給我一屋子黑,首先,有幾個普通用戶會使用Ctrl+F5? 其次,有幾個用戶愿意去Ctrl+F5?

        那么怎么辦?我想很多程序員都知道加一個版本號就可以了,這樣瀏覽器就會認為是新的文件,比如原來是 http://www.a.com/app.js你現在只需要把地址改為http://www.a.com/app.js?v=1.0 即可

        但是如果這個動作是手動的,那么10次基本上至少有5次程序員會忘掉,那么這就是為什么我們需要前端構建

        JavaScript和CSS的依賴問題

        我們經常出現的另一個問題,就是JavaScript和CSS的依賴問題,說的通俗點就是JavaScript和CSS的在頁面中的順序問題!

        我們經常發現CSS沒起作用,JavaScript的某個變量和方法找不到,有很多情況都是因為引入JavaScript或者CSS的順序不對,雖然我們可以使用一些RequireJS之類的模塊管理,但是依然在很多情況下需要引入不同的文件,尤其是CSS沒有一個好的模塊化管理的組件。

        那么我們就需要有一個統一的地方來管理JavaScript和CSS的順序問題,而構建工具可以大大減少此類問題。

        性能優化

        我們都知道瀏覽器請求的文件越多越耗時,請求的文件越大越耗時,尤其是在我們現在很多使用前端MVC, MVVM框架的時候,我們為了前端代碼更清晰,結構更合理,我們就由很多JS文件,無疑又拖慢了網頁的速度。為了解決這個問題,因此我們需要做兩件事

        文件合并

        瀏覽器需要下載多個JS文件,而瀏覽器是有并發限制,也就是同時并發只能下載幾個文件,假如瀏覽器并發數是5,你有20個JS文件,而每5個需要2S, 那么你光下載JS文件都需要8S,那么網頁的性能可想而知,所以我們需要合并多個文件以減少文件的數量。

        文件壓縮

        我們知道文件越大,下載越慢,而針對JavaScript和CSS, 里面的空格,換行這些都是為了讓我們讀代碼時更容易閱讀,但是對機器來說,這些對它沒有影響,所以為了減少文件大小,一般的情況我們都會用工具去掉空格和換行,有時候我們還會用比較短的變量名(記住這個要讓工具最后壓縮時做,而源代碼一定要保證命名可讀性) 來減少文件大小。

        而所有的前端構建工具都具有文件合并和壓縮的功能。

        效率提升

        Vendor前綴

        在CSS3使用越來越多的時候,我們都知道一些CSS的特性,不同的瀏覽器CSS有不同的前綴,如果我們手工添加將會很繁瑣,而如果使用構建工具,很多構建工具可以自動給我添加CSS的Vendor前綴

        單元測試

        JavaScript的單元測試在使用MVC或者MVVM的框架后,變得越來越容易,而單元測試是質量保證的一個很重要的手段,所以在提交之前,使用構建工具自動跑一遍我們的單元測試是非常重要的

        代碼分析

        我們寫的JavaScript很多時候會有一些潛在的bug, 比如忘了添加分號,某個變量沒有等等,使用一些JavaScript的代碼分析工具,可以很好的幫我們檢查一些常見的問題。

        HTML引用JavaScript或者CSS文件

        比如我們需要使用Bower之類來引用前端JavaScript和CSS的第三方庫,那么如果版本升級,添加移除等都用手工來修改HTML的話,第一比較耗時,第二比較容易疏漏,尤其是在我們需要切換Debug和production版本時將會有很多額外的工作,那么使用前端構建工具可以很好的解決這些問題。

        最后

        以上我只是列出了前端構建最常用的一些功能,我相信還可以發覺很多構建工具可以替代我們手工做的事,后面我將詳細講講如何使用Gulp這個神器來一一解決我們上面提到的問題。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        前端構建大法Gulp系列(一):為什么需要前端構建_html/css_WEB-ITnose

        前端構建大法Gulp系列(一):為什么需要前端構建_html/css_WEB-ITnose:我們都知道使用IDE編寫后端程序時,我們都需要Build, 對.NET來說,我們一般需要使用Visual Studio來確保我們的項目編譯通過,而且項目編譯通過是對所有程序員的基本要求。 但是,由于很多后端程序員對前端的很多東西不了解,導致在做WEB項目時出現了一些問
        推薦度:
        標簽: html 為何 css
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 免费在线视频你懂的| 日韩精品极品视频在线观看免费| 91在线手机精品免费观看| 亚洲熟妇无码另类久久久| fc2成年免费共享视频网站| 国产亚洲精久久久久久无码77777 国产亚洲精品成人AA片新蒲金 | 91视频免费网址| 亚洲欧洲日产国码二区首页| 18女人毛片水真多免费| 亚洲综合偷自成人网第页色| 成年性午夜免费视频网站不卡| 亚洲人AV在线无码影院观看| 午夜老司机免费视频| 男男gvh肉在线观看免费| 亚洲一区二区三区在线视频| 在线免费观看中文字幕| 亚洲国产成人精品无码区二本 | 最新免费jlzzjlzz在线播放| 亚洲啪AV永久无码精品放毛片| 免费看小12萝裸体视频国产| japanese色国产在线看免费| 久久精品国产99精品国产亚洲性色| 最近中文字幕免费2019| 亚洲欧美一区二区三区日产| 亚洲成人国产精品| 免费福利电影在线观看| 亚洲一日韩欧美中文字幕在线| 亚洲AV无码成人精品区大在线| 中文字幕乱码系列免费| 亚洲a级片在线观看| 亚洲AV无码乱码在线观看牲色| 免费网站观看WWW在线观看| 亚洲午夜电影在线观看高清| 国产无遮挡裸体免费视频| 国产自国产自愉自愉免费24区| 亚洲国产片在线观看| 亚洲伦乱亚洲h视频| 中文字幕乱码免费视频| 一级女性全黄生活片免费看| 亚洲高清日韩精品第一区| 免费大香伊蕉在人线国产|