這里的離線處理指線下把一些事件提前做好,不在應用運行時再去做
其實前端的離線處理在一些工具中可以看到,比如說css中的背景圖,某些css工具在打包處理的時候,如果圖片的文件大小比較小,工具會讀取文件內(nèi)容轉成base64直接放到css文件內(nèi),減少http請求。
類似的還有使用字符串模板的情況下,提前把字符串模板變成js中的函數(shù),避免運行時再去生成相應的函數(shù)
接下來聊聊其他的離線處理
模板的離線處理 自定義標簽現(xiàn)在很多前端框架支持自定義標簽的書寫方式,比如基于vue的element。我們以它的inputnumber為例來看一下: http://element.eleme.io/#/en-US/component/input-number
一個自定義的el-input-number標簽,最終生成的html是
vue會把自定義標簽替換成最終實現(xiàn)的html內(nèi)容,這個過程是運行時做的。其實這個過程是可以通過工具線下處理好的,不必在程序運行時再做。
字符串模板字符串模板在很多前端頁面中可見,模板引擎也很多,以underscore中的template方法為例:https://github.com/jashkenas/underscore/blob/master/underscore.js#L1579,它里面在生成函數(shù)時,如果沒有variable參數(shù),則會加一個with語句,通常我們是避免掉with的
那么有沒有什么辦法是不用傳variable,也不使用with語句呢?這個也是可以線下處理好的。
比如模板如下
<%for(var i=0;i<%=list[i].text%> <%}%>
通過工具我們是很容易轉換成下面的內(nèi)容的
<%for(var i=0;i<%=obj.list[i].text%> <%}%>
這個就需要借助acorn類似的工具來處理了,不過肯定是可以做到的。
有的同學說這樣做是錯的,因為with語句不在運行時,根本不知道它里面的變量從哪里取值。是的,不過我們完全可以通過約定模板中用到的變量都應該在使用時,顯式傳遞
比如window上有一個getUser()方法
在去掉with前
var tmpl="<%=getUser()%>"; _.template(tmpl,{});
這時可以正常工作
通過離線工具的處理,去掉with后,模板變成了
var tmpl="<%=obj.getUser()%>"; _.template(tmp,{});
這時候就不行了,不過我們可以約定模板中使用到的都應該在調(diào)用時顯式傳遞,從而避免一些潛在的問題出現(xiàn)。
當然,這個模板字符串離線處理最好的結果是直接就是一個函數(shù)放在那里了。
css圖片的處理在我們的項目中,考慮如下文件結構
|____index.html |____index.css |____index.js
我們通常是把html和css打包時,打包到js文件中的,因為js文件可以很方便的模塊化,把html,css依附在js文件上。這樣js按需加載時,html和css也按需加載了,而且不需要為它們特殊處理。
假設它們最終打包出來index.js如下
var Magix=require("magix"); var indexHTML="..."; Magix.applyStyle("mp-ec5",".mp-et5-content{color:red}");
更多信息可參考 https://github.com/thx/magix-combine/issues/15這個打包工具。
樣式變成一個字符串放在js文件中。
我們看一個事情:在css中使用背景圖時,為了達到最佳實踐,我們希望在支持webp后綴的使用webp,在高清屏下使用2倍圖等 。如果我們用純css實現(xiàn),要寫很多media query,產(chǎn)生很多css代碼。
其實這個事情我們沒辦法離線處理,但我們可以這樣做:書寫css仍然是寫最基礎的背景圖,不去考慮webp,2倍圖等事情,也不需要寫media query之類的。在打包時,把圖片這塊調(diào)用js函數(shù)在運行時動態(tài)處理
如前面文件結構中的,假設index.css中使用了一個背景圖
.title{background-image:url(//cdn/a.png)}
我們打包到js中時,完全可以變成
var Magix=require("magix"); var ataptImg=function(img){ //處理webp 2倍圖等 return img } Magix.applyStyle("mp-ec5",".mp-et5-title{background-image:url("+adaptImg("http://cdn/a.png")+"}");
這樣可以很方便的處理掉這些事情。像阿里cdn,七牛云存儲等,都有相應的規(guī)則生成相應的webp或壓縮圖片等功能,所以我們adaptImg方法很容易實現(xiàn)
同時因為我們使用的是最基礎的css功能,所以不存在瀏覽器不兼容的問題,像css背景圖中image-set用來處理2倍圖的方案,在firefox中是不被支持的。
模板中的圖片如css中的圖片處理一樣,我們同樣可以用工具離線處理。通過識別模板中的img標簽,再對src屬性做處理即可,這樣開發(fā)時只去關注基礎功能的實現(xiàn),其它的適配都應該交由工具去實現(xiàn),最大化的解放自己。
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/80948.html
摘要:發(fā)生在很久以前的及更老的瀏覽器向過渡時期。數(shù)據(jù)始終在同源的請求中攜帶即使不需要,會在瀏覽器和服務器間來回傳遞。存儲大小數(shù)據(jù)大小不能超過。與上面問題相連,比也是明智的選擇。表現(xiàn)與結構相分離。兩種設計思想是有不同的考慮。 前言: 吾生也有涯,而知也無涯,以有涯隨無涯,殆己————莊子 閱讀本文前請做好以下心理準備:本系列文章將不定期更新。本系列文章不是很嚴謹。 前端面試之HTML篇 Pa...
摘要:為了滿足以上需求,就需要制作打包腳本和工具,來滿足正常的運維。離線資源生成工具離線資源的生成,我們提供了一個工具可以打包出增量和全量升級包。比如和需要統(tǒng)一成。 目錄 背景 離線資源生成工具 前端協(xié)助 背景 由于線上樂刻客戶端 App 第一次打開平臺 H5 需要幾秒的加載時間,這個體驗對用戶來說并不友好,為了讓用戶跳轉 H5 和跳轉到原生一樣的用戶體驗,就需要把 H5 相關的離線資源...
摘要:為了滿足以上需求,就需要制作打包腳本和工具,來滿足正常的運維。離線資源生成工具離線資源的生成,我們提供了一個工具可以打包出增量和全量升級包。比如和需要統(tǒng)一成。 目錄 背景 離線資源生成工具 前端協(xié)助 背景 由于線上樂刻客戶端 App 第一次打開平臺 H5 需要幾秒的加載時間,這個體驗對用戶來說并不友好,為了讓用戶跳轉 H5 和跳轉到原生一樣的用戶體驗,就需要把 H5 相關的離線資源...
摘要:為了滿足以上需求,就需要制作打包腳本和工具,來滿足正常的運維。離線資源生成工具離線資源的生成,我們提供了一個工具可以打包出增量和全量升級包。比如和需要統(tǒng)一成。 目錄 背景 離線資源生成工具 前端協(xié)助 背景 由于線上樂刻客戶端 App 第一次打開平臺 H5 需要幾秒的加載時間,這個體驗對用戶來說并不友好,為了讓用戶跳轉 H5 和跳轉到原生一樣的用戶體驗,就需要把 H5 相關的離線資源...
摘要:上面提到在安卓完全不需要像這樣大費周章的繞彎路,所以安卓可能就不需要這個自定義的,這樣又會導致面臨著與安卓差異化嚴重問題。前言 最早接觸離線包的概念要追溯到16年初,項目迎來大改版,其中重點項目之一就是離線包方案的制定與實施。離線包顧名思義就是將H5/CSS/JS和資源文件打包提前下發(fā)到App中,這樣App在加載網(wǎng)頁的時候實際上加載的是本地的文件,減少網(wǎng)絡請求來提高網(wǎng)頁的渲染速度,并實現(xiàn)動態(tài)...
閱讀 2440·2021-11-22 13:53
閱讀 1134·2021-09-22 16:06
閱讀 1376·2021-09-02 15:21
閱讀 1907·2019-08-30 15:55
閱讀 3127·2019-08-29 11:19
閱讀 1925·2019-08-26 13:23
閱讀 944·2019-08-23 18:23
閱讀 1760·2019-08-23 16:06