摘要:簡言之,我們認(rèn)為好的用戶體驗(yàn)從快速的內(nèi)容傳輸開始,也就意味著性能美觀。每一步我們都在探討如何在獲得好的用戶體驗(yàn)和保證設(shè)計(jì)美感的同時(shí),最小化對性能的影響。字型子集設(shè)定到目前為止,子集設(shè)定是改善網(wǎng)頁字體性能最快的方式。
作者 Declan
原文鏈接
最近更新了我們的網(wǎng)站,它是經(jīng)過了設(shè)計(jì)上的全面驗(yàn)收的。但實(shí)際上,作為軟件開發(fā)者,我們會(huì)注重很多技術(shù)相關(guān)的零碎的東西。我們的目標(biāo)是控制性能,注重性能,未來可伸展,為網(wǎng)站增添內(nèi)容是一種樂趣。接著就來告訴你,為什么我們的網(wǎng)站速度比你們的快吧(抱歉,確實(shí)是這樣的)。
性能設(shè)計(jì)在我們的項(xiàng)目中,我們每天都會(huì)和設(shè)計(jì)師和產(chǎn)品負(fù)責(zé)人討論關(guān)于平衡美觀和性能的問題。對于我們自己的網(wǎng)站,這樣做是很簡單的。簡言之,我們認(rèn)為好的用戶體驗(yàn)從快速的內(nèi)容傳輸開始,也就意味著 性能 > 美觀。
好的內(nèi)容、布局、圖片和交互是吸引用戶的重要因素。這每個(gè)因素都會(huì)影響頁面的加載時(shí)間和終端用戶體驗(yàn)。每一步我們都在探討如何在獲得好的用戶體驗(yàn)和保證設(shè)計(jì)美感的同時(shí),最小化對性能的影響。
內(nèi)容優(yōu)先我們想要把核心內(nèi)容盡快地呈現(xiàn)給用戶,意味著我們要處理好基本的 HTML 和 CSS。每個(gè)頁面都應(yīng)該達(dá)到基本的目的:傳遞信息。JS、CSS、網(wǎng)頁字體、圖片、網(wǎng)站分析等優(yōu)化都是位居于核心內(nèi)容之下的。
可控性給理想網(wǎng)站定義了標(biāo)準(zhǔn)后,我們總結(jié)出:要想達(dá)到預(yù)期效果,就要能對網(wǎng)站各方面的控制都游刃有余。我們選擇構(gòu)建自己的靜態(tài)站點(diǎn)生成器,包括資源傳輸,并且由我們自己操控。
靜態(tài)站點(diǎn)生成器我們用 Node.js 實(shí)現(xiàn)了靜態(tài)站點(diǎn)生成器。它是采用帶有簡短 JSON 頁面描述標(biāo)簽的 Markdown 文件來生成整個(gè)網(wǎng)站結(jié)構(gòu)和它所有的資源。為了包括特殊的頁面腳本,也可以附帶一個(gè) HTML 文件。以下是一個(gè)簡單化的描述標(biāo)簽和 markdown 文件,用于博客的發(fā)布,用它來生成真正的 HTML。
JSON 描述標(biāo)簽:
{ "keywords": ["performance", "critical rendering path", "static site", "..."], "publishDate": "2016-07-13", "authors": ["Declan"] }
markdown 文件:
# Why our website is faster than yours We"ve recently updated our site. Yes, it has a complete... ## Design for performance In our projects we have daily discussions...圖片傳輸
平均一個(gè) 2406kb 的網(wǎng)頁中 1535kb 是圖片。就因?yàn)閳D片在網(wǎng)站中占據(jù)了這么大的一個(gè)比例,所以它也是性能優(yōu)化的重點(diǎn)之一。
WebP格式WebP是一種現(xiàn)代圖片格式,為網(wǎng)頁圖片提供了出色的低損耗、有損壓縮。WebP格式的圖片實(shí)質(zhì)上比其它格式的小,有時(shí)可以比同樣的 JPEG 圖片小 25%。 WebP被大多數(shù)人所忽略,也沒被經(jīng)常使用。截止到寫這篇文章的時(shí)候,WebP 僅支持Chrome, Opera 和 Android (仍超過了我們50%的用戶),但我們可以優(yōu)雅降級(jí)為 JPG/PNG。
使用 元素我們可以把圖片從 WebP 優(yōu)雅地降級(jí)到其它被廣泛支持的圖片格式,如JPEG:
我們使用Scott Jehl 的 picturefill 來使那些不支持 元素的瀏覽器獲得支持,在各個(gè)瀏覽器中達(dá)到一致的效果
我們使用 作為那些不支持 或者 JS 的瀏覽器的后備元素。使用圖片的最大實(shí)例確保了它在后備方案中的可行性。
生成盡管圖片傳輸方式已經(jīng)確定了,我們?nèi)孕枰伎荚撛鯓佑行У貓?zhí)行。我喜歡 元素的功能,但不喜歡寫上面那些代碼段,尤其是寫內(nèi)容時(shí)必須把它加進(jìn)去。我們不想做這么費(fèi)力的事情:每張圖片都要寫 6 個(gè)實(shí)例,所以優(yōu)化這些圖片并且把它們寫在markdown文件的 里面。所以:
生成圖片在構(gòu)建過程中,原圖片的多個(gè)實(shí)例,包括JPG, PNG和WebP格式,我們使用 gulp responsive 來生成。
最小化圖片 在markdown文件中寫[圖片描述](image.jpg).在構(gòu)建過程中使用自定義Markdown渲染器來為已經(jīng)完全成熟的 元素編譯傳統(tǒng)的markdown圖片聲明。
SVG動(dòng)畫我們?yōu)樽约旱木W(wǎng)站選擇了特定的圖標(biāo)類型,其中SVG插圖占了主要地位。這樣做有以下幾個(gè)原因:
首先,SVG的圖片比位圖更??;
其二,SVG圖片本身就是響應(yīng)式的,有很棒的伸縮性, 所以不需要圖片生成及 元素;
最后也是很重要的一點(diǎn),就是我們可以通過CSS來不斷改變它,賦予它新的活力!我們所有的組合頁面都有一個(gè)自定義的動(dòng)態(tài)SVG圖, 可以被概述頁面所復(fù)用。這張圖片作為我們所有組合頁面的一種循環(huán)風(fēng)格,使得頁面設(shè)計(jì)一體化,同時(shí)又幾乎不會(huì)對性能造成影響。請看這張動(dòng)畫,看看我們是如何用CSS來改變它的。
自定義網(wǎng)頁字體在深入之前,這里有一個(gè)關(guān)于在瀏覽器設(shè)置自定義字體的簡短介紹。當(dāng)瀏覽器發(fā)現(xiàn)CSS里面有@font-face 的定義,但是用戶的電腦并不支持該字體時(shí),它會(huì)嘗試下載該字體文件。在下載時(shí),多數(shù)瀏覽器根本不會(huì)用這種字體來展示文本。這種現(xiàn)象稱為“不可見文本的閃現(xiàn)” 或者 FOIT。如果你有留意,你會(huì)發(fā)現(xiàn)網(wǎng)頁上都有這種情況存在。如果你問我,我會(huì)告訴你這會(huì)影響用戶體驗(yàn)。它延遲了用戶讀取他們所需內(nèi)容的時(shí)間。我們可以迫使瀏覽器改變這種行為,變成 “無樣式內(nèi)容閃現(xiàn)” 或者稱為 FOUT。我們告訴瀏覽器先使用普通字體,像 Arial 或者 Georgia。當(dāng)自定義的字體下載完成后,再代替標(biāo)準(zhǔn)字體并且重新渲染。這樣,即使自定義字體下載失敗,仍然不會(huì)影響內(nèi)容的可讀性。然而,有人會(huì)認(rèn)為這是一種妥協(xié)的做法,但我們認(rèn)為自定義字體只是一種優(yōu)化。盡管沒有自定義字體,網(wǎng)頁看起來也完好,也能百分百的正常運(yùn)行。勾選/不勾選復(fù)選框來切換我們的網(wǎng)頁字體,來自己體驗(yàn)一下:
切換下載的字體類
使用自定義網(wǎng)頁字體可以改善我們的用戶體驗(yàn),只要你能夠優(yōu)化他們,并且負(fù)責(zé)任地為之服務(wù)。
到目前為止,子集設(shè)定是改善網(wǎng)頁字體性能最快的方式。我將會(huì)向每個(gè)使用自定義字體的網(wǎng)頁開發(fā)者推薦它。如果你能完全控制網(wǎng)頁內(nèi)容,并且知道它將要展示哪些特性的話,你可以完全使用子集設(shè)定。但是,即使是僅僅把字體設(shè)為西方語言,也會(huì)對文件大小造成很大的影響。例如,我們的 Noto Regular WOFF 字體,默認(rèn)是246KB,將其設(shè)為西方語言后,大小下降到31KB。我們使用 Font squirrel webfont, 這種字體真的很易用。
字體監(jiān)聽器Bram Stein 推出的字體監(jiān)聽器是一個(gè)很了不起的腳本,可以幫助檢查字體是否已被加載。至于你是如何加載字體的,是通過一個(gè)網(wǎng)頁字體服務(wù),還是自己上傳就不可知了。在這個(gè)監(jiān)聽器告訴我們所有自定義的字體已經(jīng)下載完畢后,我們就可以在 元素上添加一個(gè)字體加載完畢的類,我們的頁面就會(huì)重新用新的字體:
html { font-family: Georgia, serif; } html.fonts-loaded { font-family: Noto, Georgia, serif; }
注意: 為了簡短,我沒有給上面CSS中的 Noto 加上 @font-face 的聲明。
我們可以設(shè)定一個(gè)cookie來記住所有的字體已經(jīng)被加載過,就可以讓他們緩存在瀏覽器里面了。我們使用這個(gè)cookie來做重復(fù)的瀏覽,這個(gè)我后續(xù)會(huì)解釋。
在不久的將來,我們或許不需要 Bram Stein 的腳本來監(jiān)聽這個(gè)行為。CSS開發(fā)團(tuán)隊(duì)已經(jīng)提案一個(gè)新的 @font-face 描述器,也叫 font-display。它的屬性值控制著一個(gè)可下載的字體是如何在還沒加載出來時(shí)就渲染頁面的。這是CSS對font-display的描述:它將帶給我們像上面方法一樣的行為效果。你可以讀讀更多關(guān)于 font-display 的屬性。
JS和CSS懶加載一般來講,我們都是盡可能快的加載需要的資源。我們移除一些堵塞的請求來加快頁面渲染,優(yōu)化首屏,用瀏覽器緩存來處理重復(fù)的頁面。
JS懶加載設(shè)計(jì)上,我們的網(wǎng)站并沒有很多JS。我們發(fā)展了一個(gè)JavaScript工作流來處理我們目前已有的js, 以及未來會(huì)用到的js資源。
JS在 塊里面渲染,這是我們想要的。JS應(yīng)該只是用來提高用戶體驗(yàn),不應(yīng)該是訪問者需要的關(guān)鍵。處理JS堵塞渲染的簡單方法就是把腳本放在頁面的尾部。這樣網(wǎng)頁就會(huì)在整個(gè)HTML 渲染完畢后才去加載JS。
另一種可以把腳本放在 head 執(zhí)行的方案是在 標(biāo)簽里面添加 defer 屬性,來延遲腳本的執(zhí)行。由于瀏覽器下載腳本是很快的,不會(huì)堵塞頁面渲染進(jìn)程,等到頁面完全加載完,才會(huì)執(zhí)行腳本里面的代碼。還有一件事,我們沒有使用像jQuery這些庫,所以我們的腳本取決于 vanilla 腳本的特性。我們只是想要在瀏覽器加載腳本來支持這些特性。最終的結(jié)果就像下面的代碼這樣:
"); }
我們把這小段腳本放在頁面頭部,來檢測瀏覽器是否支持原生JavaScript的 document.querySelector 和 window.addEventListener 屬性。如果支持,我們通過 標(biāo)簽直接給頁面加載腳本,并使用 defer 屬性讓它不會(huì)堵塞頁面渲染。
懶加載CSS對于首屏來講,網(wǎng)站最大的渲染堵塞資源就是CSS了。只有當(dāng) 里面的CSS文件完全加載完畢時(shí),瀏覽器才會(huì)開始渲染頁面。這種做法是經(jīng)過深思熟慮的,若不是這樣,瀏覽器就需要在整個(gè)渲染過程中不斷重新計(jì)算布局尺寸,不斷重繪。
為了防止CSS堵塞渲染,我們就需要異步加載CSS文件。我們使用了 Filament Group 的 awesome loadCSS 函數(shù)。該函數(shù)提供了一個(gè)回調(diào),當(dāng)CSS文件加載完后,我們設(shè)置一個(gè)cookie來聲明CSS文件已經(jīng)加載了。我們使用這個(gè)cookie來重現(xiàn)頁面,這一點(diǎn)我后續(xù)會(huì)解釋到。
CSS異步加載也帶來這樣一個(gè)問題,盡管 HTML 真的很快被渲染出來,但看起來就只有純粹的HTML,只有等到整個(gè)CSS文件加載完且停止時(shí),才會(huì)有樣式。這時(shí)就要提到關(guān)鍵CSS了。
關(guān)鍵CSS關(guān)鍵CSS就是阻塞瀏覽器渲染出用戶可識(shí)別的網(wǎng)頁的一小部分CSS。我們注意網(wǎng)頁的 上半版版面。很明顯,兩個(gè)設(shè)備的版面的位置有很大的區(qū)別。因此,我們做了一個(gè)大膽的猜測。
手動(dòng)地檢測這部分關(guān)鍵性的CSS是個(gè)很耗時(shí)的過程,尤其是樣式、特性等不斷改變時(shí)。這里有幾個(gè)好的腳本,可以在你構(gòu)建網(wǎng)頁時(shí),生成關(guān)鍵性CSS。我們采用了 Addy Osmani 的版本。
下面是我們分別用關(guān)鍵性CSS和整份CSS分別渲染的頁面效果。注意到下半版仍然有部分內(nèi)容還沒有樣式。
左側(cè)網(wǎng)頁是用關(guān)鍵CSS渲染的,而右側(cè)網(wǎng)頁則是用整份的CSS。紅線是分界線。
服務(wù)端我們自己部署 de Voorhoede 網(wǎng)站,因?yàn)槲覀兿M軌蚩刂品?wù)器環(huán)境。我們也想要嘗試,是否可以通過改變服務(wù)端的配置來大大提升性能。當(dāng)前我們使用了 Apache 服務(wù)和 HTTPS 協(xié)議。
配置為了提升性能和安全性,我們研究了如何配置服務(wù)端。
我們使用 H5BP apache樣板配置,這個(gè)對于改善Apache網(wǎng)絡(luò)服務(wù)的性能和安全性是個(gè)很好的開始。他們也有其他服務(wù)器環(huán)境的配置。對于我們的大部分 HTML、CSS 和 JS,我們使用GZIP壓縮。對于我們的所有網(wǎng)站資源,都使用緩存HTTP標(biāo)頭的做法。有興趣請閱讀文件層級(jí)緩存的章節(jié)。
HTTPS用HTTPS來服務(wù)你的網(wǎng)站會(huì)對性能造成影響。這主要是設(shè)置了SSL握手,引入了大量潛在的東西。但通常情況下,我們可以做一些改變!
HTTP Strict Transport Security 是一個(gè)HTTP標(biāo)頭,可以讓服務(wù)器告訴瀏覽器只能用HTTPS來與它交互。這種方式防止HTTP請求被重定向?yàn)镠TTPS。所有嘗試用HTTP來訪問站點(diǎn)的請求都會(huì)被自動(dòng)轉(zhuǎn)換成HTTPS。這樣就節(jié)省了一個(gè)來回。
TLS false start 允許客戶端在第一個(gè)TLS回合結(jié)束后,馬上向后端發(fā)送加密的數(shù)據(jù)。這種優(yōu)化為一個(gè)新的TLS連接減少了握手次數(shù)。一旦客戶端知道了密鑰,就可以開始傳輸應(yīng)用數(shù)據(jù)。剩下的握手用來確認(rèn)是否有人篡改了握手記錄,并且可以并行處理。
TLS session resumption 通過確認(rèn)瀏覽器和服務(wù)器是否已經(jīng)取得聯(lián)系來幫我們節(jié)省一個(gè)來回。瀏覽器會(huì)記住這一次的標(biāo)識(shí)符,下次發(fā)起連接時(shí),這個(gè)標(biāo)識(shí)符就會(huì)被重用,節(jié)省了一個(gè)來回。
我聽起來像是一個(gè)搞開發(fā)和運(yùn)維的,但確實(shí)不是。我只是讀過一些書,看過一些視頻。我喜歡 Google I/O 2016 的 Mythbusting HTTPS:Emily Stark 的安全性都市傳奇。
cookies的使用我們沒有用一門服務(wù)端的語言,只有靜態(tài)的 Apache 網(wǎng)絡(luò)服務(wù)。但一個(gè) Apache 網(wǎng)絡(luò)服務(wù)仍可以做包括SSI在內(nèi)的后端服務(wù),并且讀取cookies。通過巧用cookies和運(yùn)行那部分被Apache改寫的HTML,我們可以大大提升前端性能。下面這個(gè)例子就是了(我們實(shí)際的代碼比這個(gè)復(fù)雜點(diǎn),但是思想上是一致的):
Apache 服務(wù)端邏輯看起來像一行一行的備注,一般以 如果是true的話,我們就假定這是用戶的第一次瀏覽。
第一次瀏覽我們添加了 標(biāo)簽,里面放置了 。之所以這樣做,是因?yàn)槲覀円惒郊虞d整份CSS和JS。如果JS不能用的話,這種做法是不能執(zhí)行的。這意味著,我們要用常規(guī)的加載CSS的方法來做回退。
我們添加了一個(gè)行內(nèi)的腳本來懶加載CSS,onloadCSS 回調(diào)里面可以設(shè)置cookies.
在同一份腳本里面,我們異步加載了整份CSS。
在 onloadCSS的回調(diào)里面,我們用版本號(hào)來設(shè)置cookie的值。
在這個(gè)腳本后面,我們添加了一行關(guān)鍵CSS的樣式。這個(gè)會(huì)阻塞渲染,但時(shí)間是非常短的,而且可以避免頁面展示出來只有純粹的HTML而沒有樣式的情況。
聲明(意味著 css-loaded 的cookie 已經(jīng)存在)用戶重復(fù)瀏覽。因?yàn)槲覀兛梢詮哪撤N程度上來假定,CSS文件之前已經(jīng)被加載過了,我們可以利用瀏覽器緩存來提供樣式表。這樣從緩存里面加載速度就很快了。同樣的方法也被用來在第一次異步加載字體,后續(xù)的重復(fù)瀏覽也是從緩存里面獲取字體。
這就是我們第一次和重復(fù)瀏覽時(shí),我們用來區(qū)分的cookies。
文件級(jí)緩存由于我們在重現(xiàn)頁面時(shí)很大程度上依賴于瀏覽器緩存,所以我們需要確認(rèn)我們的緩存是否合理。理想中我們是要永遠(yuǎn)的存儲(chǔ)資源(CSS、js、 字體、圖片),只有當(dāng)這些文件被修改時(shí)才需要更新。當(dāng)請求的URL是唯一時(shí),緩存就會(huì)失效。每更新一個(gè)版本,我們都會(huì)用 git tag 打個(gè)標(biāo)簽。所以最簡單的方式就是給我們請求的URL加上一個(gè)參數(shù)(代碼版本號(hào)),如 https://www.voorhoede.nl/assets/css/main-8af99277a6.css?v=1.0.4.。
但是,這種做法的缺點(diǎn)就是當(dāng)我們要寫一個(gè)新的博客post(這也是我們代碼庫的一部分,并沒有永久地存儲(chǔ)在CMS),原來緩存的資源將會(huì)失效,盡管沒有改變原來那些資源。
就在我們嘗試去改善這種方法時(shí),我們發(fā)現(xiàn)了 gulp-rev 和 gulp-rev-replace 。這些腳本會(huì)自動(dòng)合理地在我們的文件名稱后面添加一竄hash值。這意味著只有實(shí)際上文件被改變時(shí),才會(huì)去改變請求的URL,這樣每個(gè)文件的緩存就會(huì)自動(dòng)失效。這種做法讓我興奮不已??!
結(jié)果如果你看到這里,你應(yīng)該是想要知道結(jié)果的。測試網(wǎng)頁的性能可以采用像 PageSpeed Insights 這樣的工具,它有很實(shí)用的提示。也可以使用 WebPagetest來測試,有擴(kuò)展性的網(wǎng)絡(luò)分析。我認(rèn)為測試網(wǎng)頁渲染性能的最好方法就是在瘋狂地遏制網(wǎng)絡(luò)通信時(shí)來觀察網(wǎng)頁的進(jìn)程。這意味著,用一種不切實(shí)際的方法來遏制通信。在谷歌瀏覽器,你可以這樣操作 (via the inspector > Network tab) 來限制通信,觀察網(wǎng)頁形成過程中,請求是如何緩慢加載的。
下面是我們的網(wǎng)頁在 50KB/s 的情況下的加載狀況。
這是 de Voorhoede site 首屏的網(wǎng)絡(luò)分析,是網(wǎng)頁第一次進(jìn)程的一個(gè)概覽。
注意到在50KB/s的網(wǎng)速中,我們是如何讓首屏的渲染只用了 2.27 秒的。也就是第一張幻燈片和瀑布圖里面的黃色線所代表的位置。黃線恰好繪在就是HTML已經(jīng)加載完的時(shí)間位置。HTML包含了關(guān)鍵CSS,保證頁面的可觀性。所有其他的CSS都是用懶加載,所以我們可以等到全部資源加載完時(shí)才與頁面進(jìn)行交互。這也是我們想要的效果!
另一個(gè)值得注意的就是自定義字體從來不在這緩慢的鏈接上加載。 font face 觀察器會(huì)自動(dòng)注意到這一點(diǎn)。但是,如果我們不異步加載字體,你注視大多數(shù)瀏覽器,都會(huì)出現(xiàn) FOIT(不可見文本的閃現(xiàn),上文有提及)的情況。
所有的CSS文件僅在8s后就都加載完畢。相反,如果我們不采用加載關(guān)鍵CSS的方式,而是采用加載全部CSS,我們在前8秒看到的將會(huì)是空白的頁面。
如果你感到好奇,想與那些不太注重性能的網(wǎng)站對比一下加載時(shí)間,那趕緊試試吧。那個(gè)時(shí)間肯定是飛漲啊!
用上面介紹的工具測試了我們的網(wǎng)站,結(jié)果也是讓人滿意的。 PageSpeed insights 在移動(dòng)性能方面給了我們100分,多么了不起??!
PageSpeed insights 對 voorhoede.nl的測試結(jié)果! 速度100分!
當(dāng)我們查看 WebPagetest 時(shí),我們得到下面這樣的結(jié)果:
WebPagetest 對 voorhoede.nl的檢測結(jié)果
可以看出,我們的服務(wù)器運(yùn)行良好,首屏的速度指標(biāo)是693。 這意味著我們的頁面在693毫秒后就可以在寬屏纜線下被使用了。
技術(shù)路線我們這樣還不算完成,還會(huì)不斷地重復(fù)我們的方法。我不久的將來,我們會(huì)主要關(guān)注以下內(nèi)容:
HTTP/2目前我們正在試驗(yàn)HTTP/2。本文所描述的大多數(shù)東西都是基于 HTTP/1.1 權(quán)限內(nèi)的最好實(shí)踐。簡言之,HTTP/1.1 要追述到1999年,那時(shí) table布局和行內(nèi)樣式都如火如荼。HTTP/1.1 從沒為 2.6MB的網(wǎng)頁要接受200個(gè)請求而設(shè)計(jì)。為了減輕舊版協(xié)議帶來的痛楚,我們結(jié)合JS、CSS、關(guān)鍵性CSS,還為小圖片設(shè)置數(shù)據(jù)源URI等。用各種方法來節(jié)省請求。自從 HTTP/2 可以在同一個(gè)TCP鏈接上平行地運(yùn)行多個(gè)請求后,所有的這些聯(lián)結(jié)使用和減少請求的做法都可能成為反面模式了。當(dāng)我們跑完這個(gè)實(shí)驗(yàn)后,我們將會(huì)采用 HTTP/2 協(xié)議。
Service Workers這是一個(gè)在后臺(tái)運(yùn)行的現(xiàn)代瀏覽器的 JavaScript API。它擁有很多特性,這些特性在以前的網(wǎng)站上都是沒有的,如離線支持、消息推送、背景同步等。我們現(xiàn)在正嘗試用 Service Worker, 但還是得在我們自己的網(wǎng)站上實(shí)現(xiàn)先。我向你保證,我們會(huì)做到的!
CDN因此,我們想要自己控制和部署我們的網(wǎng)站。而且現(xiàn)在我們也要采用CDN來擺脫由服務(wù)端和客戶端實(shí)際距離所帶來的網(wǎng)絡(luò)問題。盡管我們的用戶基本上都是荷蘭的,我們也想向世界的前端社區(qū)反映我們在質(zhì)量、性能和推動(dòng)網(wǎng)絡(luò)發(fā)展方面做的最好。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/87881.html
摘要:簡言之,我們認(rèn)為好的用戶體驗(yàn)從快速的內(nèi)容傳輸開始,也就意味著性能美觀。每一步我們都在探討如何在獲得好的用戶體驗(yàn)和保證設(shè)計(jì)美感的同時(shí),最小化對性能的影響。字型子集設(shè)定到目前為止,子集設(shè)定是改善網(wǎng)頁字體性能最快的方式。 作者 Declan 原文鏈接 最近更新了我們的網(wǎng)站,它是經(jīng)過了設(shè)計(jì)上的全面驗(yàn)收的。但實(shí)際上,作為軟件開發(fā)者,我們會(huì)注重很多技術(shù)相關(guān)的零碎的東西。我們的目標(biāo)是控制性能,注重性...
摘要:簡言之,我們認(rèn)為好的用戶體驗(yàn)從快速的內(nèi)容傳輸開始,也就意味著性能美觀。每一步我們都在探討如何在獲得好的用戶體驗(yàn)和保證設(shè)計(jì)美感的同時(shí),最小化對性能的影響。字型子集設(shè)定到目前為止,子集設(shè)定是改善網(wǎng)頁字體性能最快的方式。 作者 Declan 原文鏈接 最近更新了我們的網(wǎng)站,它是經(jīng)過了設(shè)計(jì)上的全面驗(yàn)收的。但實(shí)際上,作為軟件開發(fā)者,我們會(huì)注重很多技術(shù)相關(guān)的零碎的東西。我們的目標(biāo)是控制性能,注重性...
摘要:簡言之,我們認(rèn)為好的用戶體驗(yàn)從快速的內(nèi)容傳輸開始,也就意味著性能美觀。每一步我們都在探討如何在獲得好的用戶體驗(yàn)和保證設(shè)計(jì)美感的同時(shí),最小化對性能的影響。字型子集設(shè)定到目前為止,子集設(shè)定是改善網(wǎng)頁字體性能最快的方式。 作者 Declan 原文鏈接 最近更新了我們的網(wǎng)站,它是經(jīng)過了設(shè)計(jì)上的全面驗(yàn)收的。但實(shí)際上,作為軟件開發(fā)者,我們會(huì)注重很多技術(shù)相關(guān)的零碎的東西。我們的目標(biāo)是控制性能,注重性...
摘要:簡言之,我們認(rèn)為好的用戶體驗(yàn)從快速的內(nèi)容傳輸開始,也就意味著性能美觀。每一步我們都在探討如何在獲得好的用戶體驗(yàn)和保證設(shè)計(jì)美感的同時(shí),最小化對性能的影響。字型子集設(shè)定到目前為止,子集設(shè)定是改善網(wǎng)頁字體性能最快的方式。 作者 Declan 原文鏈接 最近更新了我們的網(wǎng)站,它是經(jīng)過了設(shè)計(jì)上的全面驗(yàn)收的。但實(shí)際上,作為軟件開發(fā)者,我們會(huì)注重很多技術(shù)相關(guān)的零碎的東西。我們的目標(biāo)是控制性能,注重性...
摘要:端優(yōu)談?wù)勱P(guān)于前端的緩存的問題我們都知道對頁面進(jìn)行緩存能夠有利于減少請求發(fā)送,從而達(dá)到對頁面的優(yōu)化。而作為一名有追求的前端,勢必要力所能及地優(yōu)化我們前端頁面的性能。這種方式主要解決了淺談前端中的過早優(yōu)化問題過早優(yōu)化是萬惡之源。 優(yōu)化向:單頁應(yīng)用多路由預(yù)渲染指南 Ajax 技術(shù)的出現(xiàn),讓我們的 Web 應(yīng)用能夠在不刷新的狀態(tài)下顯示不同頁面的內(nèi)容,這就是單頁應(yīng)用。在一個(gè)單頁應(yīng)用中,往往只有一...
閱讀 3950·2021-11-16 11:50
閱讀 947·2021-11-11 16:55
閱讀 3671·2021-10-26 09:51
閱讀 872·2021-09-22 15:03
閱讀 3438·2019-08-30 15:54
閱讀 3272·2019-08-30 15:54
閱讀 2482·2019-08-30 14:04
閱讀 927·2019-08-30 13:53