摘要:當一個按鈕沒有名字時,屏幕閱讀器會宣布按鈕。雖然每個元素的目的對于有視覺的用戶來說可能是顯而易見的,但對于依靠屏幕閱讀器的用戶來說并非如此。屏幕閱讀器使視覺障礙的用戶能夠通過將文本內(nèi)容轉(zhuǎn)換為可以使用的表格如合成語音或盲文來使用您的網(wǎng)站。
Lighthouse是一個Google開源的自動化工具,主要用于改進網(wǎng)絡(luò)應(yīng)用(移動端)的質(zhì)量。目前測試項包括頁面性能、PWA、可訪問性(無障礙)、最佳實踐、SEO。Lighthouse會對各個測試項的結(jié)果打分,并給出優(yōu)化建議,這些打分標準和優(yōu)化建議可以視為Google的網(wǎng)頁最佳實踐。
運行Lighthouse的方式有三種:在開發(fā)者工具(Devtools)的Audits,作為Chrome拓展程序使用,或者作為命令行工具使用。Chrome開發(fā)者工具不需要額外安裝,和擴展程序一樣提供了一個用戶友好的界面,方便讀取報告;擴展程序相對于開發(fā)者工具的優(yōu)勢是更及時,不用等待Chrome發(fā)版就能體驗到最新的功能;命令行工具可以將Lighthouse集成到持續(xù)集成系統(tǒng)。
開發(fā)者工具僅能在Chrome60及以上使用,因為之前版本的Chrome的開發(fā)者工具的audits面板還不是Lighthouse。
通過右上角的菜單或者快捷鍵(command+option+i)打開開發(fā)者工具,然后選擇audits面板,點擊Perform an audits會彈出一個options面板勾選測試項然后點擊Run audits即可。
Chrome拓展程序安裝地址(需要梯子)
在右上角或者菜單里點擊圖中圖標,Options可以配置測試項目,點擊Generate report即可測試。
命令行工具安裝:
npm install -g lighthouse # or use yarn: # yarn global add lighthouse
使用:
lighthouse https://example.com
配置項:
$ lighthouse --help lighthouse測試結(jié)果示例 最佳實踐Logging: --verbose Displays verbose logging [boolean] --quiet Displays no progress, debug logs or errors [boolean] Configuration: --save-assets Save the trace contents & screenshots to disk [boolean] --list-all-audits Prints a list of all available audits and exits [boolean] --list-trace-categories Prints a list of all required trace categories and exits [boolean] --additional-trace-categories Additional categories to capture with the trace (comma-delimited). --config-path The path to the config JSON. --chrome-flags Custom flags to pass to Chrome (space-delimited). For a full list of flags, see http://peter.sh/experiments/chromium-command-line-switches/. Environment variables: CHROME_PATH: Explicit path of intended Chrome binary. If set must point to an executable of a build of Chromium version 54.0 or later. By default, any detected Chrome Canary or Chrome (stable) will be launched. [default: ""] --perf Use a performance-test-only configuration [boolean] --port The port to use for the debugging protocol. Use 0 for a random port [default: 0] --hostname The hostname to use for the debugging protocol. [default: "localhost"] --max-wait-for-load The timeout (in milliseconds) to wait before the page is considered done loading and the run should continue. WARNING: Very high values can lead to large traces and instability [default: 45000] --enable-error-reporting Enables error reporting, overriding any saved preference. --no-enable-error-reporting will do the opposite. More: https://git.io/vFFTO --gather-mode, -G Collect artifacts from a connected browser and save to disk. If audit-mode is not also enabled, the run will quit early. [boolean] --audit-mode, -A Process saved artifacts from disk [boolean] Output: --output Reporter for the results, supports multiple values [choices: "json", "html", "domhtml"] [default: "domhtml"] --output-path The file path to output the results. Use "stdout" to write to stdout. If using JSON output, default is stdout. If using HTML output, default is a file in the working directory with a name based on the test URL and date. If using multiple outputs, --output-path is ignored. Example: --output-path=./lighthouse-results.html --view Open HTML report in your browser [boolean] Options: --help Show help [boolean] --version Show version number [boolean] --blocked-url-patterns Block any network requests to the specified URL patterns [array] --disable-storage-reset Disable clearing the browser cache and other storage APIs before a run [boolean] --disable-device-emulation Disable Nexus 5X emulation [boolean] --disable-cpu-throttling Disable CPU throttling [boolean] [default: false] --disable-network-throttling Disable network throttling [boolean] --extra-headers Set extra HTTP Headers to pass with request [string] Examples: lighthouse --view Opens the HTML report in a browser after the run completes lighthouse --config-path=./myconfig.js Runs Lighthouse with your own configuration: custom audits, report generation, etc. lighthouse --output=json --output-path=./report.json --save-assets Save trace, screenshots, and named JSON report. lighthouse --disable-device-emulation --disable-network-throttling Disable device emulation lighthouse --chrome-flags="--window-size=412,732" Launch Chrome with a specific window size lighthouse --quiet --chrome-flags="--headless" Launch Headless Chrome, turn off logging lighthouse --extra-headers "{"Cookie":"monster=blue"}" Stringify"d JSON HTTP Header key/value pairs to send in requests lighthouse --extra-headers=./path/to/file.json Path to JSON file of HTTP Header key/value pairs to send in requests For more information on Lighthouse, see https://developers.google.com/web/tools/lighthouse/.
這些最佳實踐主要針對移動端或者Web應(yīng)用。某些技術(shù)對瀏覽器版本要求較高,用之前最好在Can I use、MDN上查一下瀏覽器支持情況
當頁面使用 target="_blank" 跳轉(zhuǎn)至另一個頁面時,新頁面將與您的頁面在同一個進程上運行。 如果新頁面正在執(zhí)行開銷極大的 JavaScript,您的頁面性能可能會受影響。最重要的是target="_blank”也是一個安全漏洞。新頁面可以通過window.opener訪問舊頁面的window對象,并且它可以使用window.opener.location=newURL將舊頁面導(dǎo)航至不同的網(wǎng)址。所以當在新窗口或標簽中打開一個外部鏈接時,應(yīng)該始終加上rel="noopener",例如:
...
就是地址欄的背景顏色應(yīng)該和品牌顏色一致
通過meta標簽實現(xiàn)的:
不過僅在認可這個meta的瀏覽器上有效,比如Chrome for Android,實測pc、ios的Chrome、Safari無效。
如果場景能用上還是能提高一些用戶體驗的,避免了地址欄突兀。
AppCache已被廢棄
考慮使用service worker的Cache API,另外現(xiàn)在ios 11.3也支持了service worker,未來一兩年應(yīng)該有很大發(fā)展。
如果使用console.time()測試頁面性能,請考慮使用User Timing API。其優(yōu)勢包括:
高分辨率時間戳
可導(dǎo)出的計時數(shù)據(jù)
與Chrome Devtools TImeline相集成。在 Timeline 錄制期間調(diào)用 User Timing 函數(shù) performance.measure() 時,DevTools 自動將此測量結(jié)果添加到 Timeline 的結(jié)果中。
將console.time()替換為performance.mark()。如果需要測量兩個label之間經(jīng)過的時間,則使用performance.measure()。User Timing API
// 獲得命名時間戳 window.performance.mark("mark_fully_loaded"); // 獲得命名時間戳之間的時間間隔或者與PerformanceTiming的時間間隔 window.performance.measure("measure_load_from_dom", "domComplete", "mark_fully_loaded");
考慮改用performance.now()代替Date.now()。performance.now()可提供較高的時間戳分辨率,并始終以恒定的速率增加,它不受系統(tǒng)時鐘(可以調(diào)整)的影響。performance.now()
// 獲取相對于navigationStart屬性中的時間戳為起點開始計時的精確到千分之一毫秒的時間戳 window.performance.now()
已棄用的API計劃從Chrome中移除,使用這些API后,被刪除后將導(dǎo)致網(wǎng)頁出錯。查看Chrome平臺狀態(tài)
對于網(wǎng)速較慢(2G、3G或較慢的WLAN)的用戶,外部腳本通過document.write()動態(tài)注入會使頁面內(nèi)容的顯示延遲數(shù)十秒。
延遲請求直到需要它們
啟用文本壓縮
壓縮HTML、JS和CSS
使用Webp而不是JPEG或PNG
將JPEG圖像的壓縮級別設(shè)置為85
緩存請求
以下mutation events會損害性能,在DOM事件規(guī)范中已經(jīng)棄用:
DOMAttrModified
DOMAttributeNameChanged
DOMCharacterDataModified
DOMElementNameChanged
DOMNodeInserted
DOMNodeInsertedIntoDocument
DOMNodeRemoved
DOMNodeRemovedFromDocument
DOMSubtreeModified
建議將每個mutation events替換成MutationObserver
2009年的舊Flexbox規(guī)范已棄用,其速度比最新的規(guī)范慢2.3倍。將頁面中的display:box及以box開頭的每個屬性替換成標準的Flexbox屬性。
頁面在加載時自動請求用戶位置會使用戶不信任頁面或感到困惑。應(yīng)將此請求與用戶的手勢進行關(guān)聯(lián),而不是在頁面加載時自動請求用戶的位置。
好的通知需要做到及時、相關(guān)且準確。如果頁面在加載時要求權(quán)限以發(fā)送通知,則這些通知可能與您的用戶無關(guān)或者不是他們的精準需求。為提高用戶體驗,最好是向用戶發(fā)送特定類型的通知,并在他們選擇加入后顯示權(quán)限請求。
Web SQL已棄用,建議替換為IndexedDB
低對比度文本對于許多用戶來說很難或不可能讀取
使用Chrome擴展程序aXe可以分析出所有的可訪問性問題
沒有名字的按鈕對依賴屏幕閱讀器的用戶不可用。當一個按鈕沒有名字時,屏幕閱讀器會宣布“按鈕”。
對
設(shè)置元素的內(nèi)部文本
設(shè)置aria-label屬性
將該aria-labelledby屬性設(shè)置為屏幕閱讀器可見的文本元素。
對于的元素:
設(shè)置value屬性
設(shè)置aria-label屬性
設(shè)置aria-labelledby屬性
對于和:
設(shè)置value屬性,或省略它。瀏覽器在value省略時賦予"submit"或"reset"的默認值
設(shè)置aria-label屬性
設(shè)置aria-labelledby屬性
基本內(nèi)容和頁面功能不應(yīng)該依賴于CSS或JS。對于必需依賴JavaScript的頁面,一種方法是使用一個
將關(guān)鍵資源數(shù)降至最低:消除關(guān)鍵資源、延遲關(guān)鍵資源的下載并將它們標記為不同步等。
優(yōu)化關(guān)鍵字節(jié)數(shù)以縮短下載時間。
優(yōu)化其余關(guān)鍵資源的加載順序:盡早下載所有關(guān)鍵資產(chǎn),以縮短關(guān)鍵路徑長度。
如果渲染的圖像與其源文件中的長寬比不同,則呈現(xiàn)的圖像可能看起來失真,產(chǎn)生不愉悅的用戶體驗。
避免將元素的寬度或高度設(shè)置為可變大小的容器的百分比。
避免設(shè)置不同于源圖像尺寸的顯式寬度或高度值。
考慮使用css-aspect-ratio或?Aspect Ratio Boxes來幫助保留寬高比。
如果可能的話,在HTML中指定圖片的寬度和高度是一個很好的做法,這樣瀏覽器就可以為圖片分配空間,這樣可以防止頁面在加載時跳過。在HTML中而不是CSS中指定寬度和高度是更理想的,因為瀏覽器在解析CSS之前分配空間。實際上,如果您使用響應(yīng)式圖像,則此方法可能很困難,因為在知道視口尺寸之前無法指定寬度和高度。
如果瀏覽器支持,則配置服務(wù)器以使用Brotli壓縮響應(yīng)。Brotli比GZIP可以節(jié)省更多的流量。如果不支持Brotli則使用GZIP。在Chrome DevTools檢查響應(yīng)是否被壓縮:
打開DevTools的Network面板
點擊指定的回復(fù)的請求。
點擊Headers選項卡
檢查Response Headers中content-heading字段
輸入響應(yīng)能力對用戶如何看待應(yīng)用的性能起著關(guān)鍵作用。應(yīng)用有100毫秒的時間響應(yīng)用戶輸入。如果超過此時間,用戶就會認為應(yīng)用反應(yīng)遲緩。
對于動畫效果的實現(xiàn),避免使用setTimeout或setInterval,請使用requestAnimationFrame
將長時間運行的JavaScript從主線程移動到Web Worker
使用micro-tasks來執(zhí)行對多個幀的DOM更改
使用Chrome DevTools的Timeline和Javascript分析器來評估JavaScript的影響。
降低選擇器的復(fù)雜性(例如:nth-of-type、:nth-child);使用以類為中心的方法,例如BEM,這有一篇BEM的教程
盡可能避免布局操作,對“幾何屬性”(如寬度、高度左側(cè)或頂部)的更改都需要布局計算。布局幾乎總是作用到整個文檔,如果有大量元素,會消耗很長時間來計算出所有元素的位置和尺寸。
避免強制同步布局
首先JavaScript運行,然后計算樣式,然后布局。但是,可以使用JavaScript強制瀏覽器提前執(zhí)行布局。這被稱為強制同步布局。在JavaScript運行時,來自上一幀的所有舊布局值是已知的,并且可供查詢。因此,如果在幀的開頭寫出一個元素的高度是沒有問題的,但是在查詢高度之前,已經(jīng)更改其樣式,如下列代碼。,就會強制頁面計算返回正確的高度。這是不必要的,并且開銷很大。始終應(yīng)先批量讀取樣式并執(zhí)行,然后執(zhí)行任何寫操作。
function logBoxHeight() { box.classList.add("super-big"); // Gets the height of the box in pixels // and logs it out. console.log(box.offsetHeight); }
除 transform 或 opacity 屬性之外,更改任何屬性始終都會觸發(fā)繪制。可以使用Chrome DevTools來快速確定正在繪制的區(qū)域。打開DevTools,按下鍵盤上的 Esc 鍵。在出現(xiàn)的面板中,轉(zhuǎn)到“rendering”標簽,然后選中“Show paint rectangles”。
每一個表單元素都應(yīng)該有一個label
label闡明了表單元素的用途。雖然每個元素的目的對于有視覺的用戶來說可能是顯而易見的,但對于依靠屏幕閱讀器的用戶來說并非如此。有四種方式可以實現(xiàn):
隱含標簽
顯式標簽
aria-label
aria-labelledby
Select seat:...
每個圖像都有一個alt屬性
信息性圖像應(yīng)該具有alt包含該圖像內(nèi)容的文本描述的屬性。屏幕閱讀器使視覺障礙的用戶能夠通過將文本內(nèi)容轉(zhuǎn)換為可以使用的表格(如合成語音或盲文)來使用您的網(wǎng)站。屏幕閱讀器無法轉(zhuǎn)換圖像。因此,如果您的圖片包含重要信息,那么視覺障礙用戶無法獲取該信息。
可以在DevTools的Console選項卡中使用以下命令來查找沒有alt屬性的圖片
$$("img:not([alt])");
在Console中$$()相當于document.querySelectorAll()
配置HTML的Viewport meta標簽
如果沒有Viewport meta標簽,移動設(shè)備將以典型的桌面設(shè)備屏幕寬度渲染頁面,然后對頁面進行縮放以適合移動設(shè)備屏幕。通過Viewport meta標簽可以控制寬度和縮放比例。
配置視口 設(shè)置視口
width=device-width鍵值對將視口寬度設(shè)置為設(shè)備寬度。在訪問頁面時,initial-scale=1鍵值對設(shè)置初始縮放級別。
... ...
壓縮圖片(僅針對JPEG)
將每個圖像的壓縮級別設(shè)置為85或更低,像TinyJPG這樣的Web服務(wù)可以幫助自動化圖像優(yōu)化的過程
搜索引擎可能無法正確索引返回不成功的HTTP狀態(tài)碼的頁面。
密碼粘貼提高了安全性,因為它使用戶能夠使用密碼管理器。密碼管理員通常為用戶生成強密碼,安全地存儲密碼,然后在用戶需要登錄時自動將其粘貼到密碼字段中。
刪除阻止用戶粘貼到密碼字段的代碼。使用事件斷點中的Clipboard paste來打斷點,可以快速找到阻止粘貼密碼的代碼。比如下列這種阻止粘貼密碼的代碼:
let input = document.querySelector("input"); input.addEventListener("paste", (e) => { e.preventDefault(); // This is what prevents pasting. });
大型的DOM樹會以多種方式降低頁面性能:
網(wǎng)絡(luò)效率和負載性能,如果你的服務(wù)器發(fā)送一個大的DOM樹,你可能會運送大量不必要的字節(jié)。這也可能會減慢頁面加載時間,因為瀏覽器可能會解析許多沒有顯示在屏幕上的節(jié)點。
運行時性能。當用戶和腳本與頁面交互時,瀏覽器必須不斷重新計算節(jié)點的位置和樣式。一個大的DOM樹與復(fù)雜的樣式規(guī)則相結(jié)合可能會嚴重減慢渲染速度。
內(nèi)存性能。如果使用通用查詢選擇器(例如,document.querySelectorAll("li") 您可能會無意中將引用存儲到大量的節(jié)點),這可能會壓倒用戶設(shè)備的內(nèi)存功能。
一個最佳的DOM樹:
總共少于1500個節(jié)點。
最大深度為32個節(jié)點。
沒有超過60個子節(jié)點的父節(jié)點。
一般來說,只需要在需要時尋找創(chuàng)建DOM節(jié)點的方法,并在不再需要時將其銷毀。
如果你不能避免一個大型的DOM樹,改善渲染性能的另一種方法是簡化你的CSS選擇器。請參閱減少風格計算的范圍和復(fù)雜性。
被動事件是新興的Web標準,可以顯著提高滾動性能,尤其在移動設(shè)備上。當使用touch事件監(jiān)聽器(scroll事件不存在這個問題)進行滾動時,因為瀏覽器不知道你是否會取消滾動,它們總是等待監(jiān)聽器執(zhí)行完畢后才開始滾動,這樣就造成了明顯的延遲。事件監(jiān)聽器options中使用passive:true表明監(jiān)聽器永遠不會取消滾動,這樣瀏覽器就可以立即滾動。
在支持被動事件偵聽器的瀏覽器中,將偵聽器標記為passive即可:
document.addEventListener("touchstart", onTouchStart, {passive: true});
求贊,歡迎訪問我的博客
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/107394.html
摘要:前端每周清單專注前端領(lǐng)域內(nèi)容,以對外文資料的搜集為主,幫助開發(fā)者了解一周前端熱點分為新聞熱點開發(fā)教程工程實踐深度閱讀開源項目巔峰人生等欄目。 前端每周清單專注前端領(lǐng)域內(nèi)容,以對外文資料的搜集為主,幫助開發(fā)者了解一周前端熱點;分為新聞熱點、開發(fā)教程、工程實踐、深度閱讀、開源項目、巔峰人生等欄目。歡迎關(guān)注【前端之巔】微信公眾號(ID:frontshow),及時獲取前端每周清單;本文則是對于...
摘要:延伸閱讀學(xué)習(xí)與實踐資料索引與前端工程化實踐前端每周清單半年盤點之篇前端每周清單半年盤點之與篇前端每周清單半年盤點之篇 前端每周清單專注前端領(lǐng)域內(nèi)容,以對外文資料的搜集為主,幫助開發(fā)者了解一周前端熱點;分為新聞熱點、開發(fā)教程、工程實踐、深度閱讀、開源項目、巔峰人生等欄目。歡迎關(guān)注【前端之巔】微信公眾號(ID:frontshow),及時獲取前端每周清單;本文則是對于半年來發(fā)布的前端每周清單...
摘要:雖然有著各種各樣的不同,但是相同的是,他們前端優(yōu)化不完全指南前端掘金篇幅可能有點長,我想先聊一聊閱讀的方式,我希望你閱讀的時候,能夠把我當作你的競爭對手,你的夢想是超越我。 如何提升頁面渲染效率 - 前端 - 掘金Web頁面的性能 我們每天都會瀏覽很多的Web頁面,使用很多基于Web的應(yīng)用。這些站點看起來既不一樣,用途也都各有不同,有在線視頻,Social Media,新聞,郵件客戶端...
摘要:前端每周清單第期與模式變遷與優(yōu)化界面生成作者王下邀月熊編輯徐川前端每周清單專注前端領(lǐng)域內(nèi)容,以對外文資料的搜集為主,幫助開發(fā)者了解一周前端熱點分為新聞熱點開發(fā)教程工程實踐深度閱讀開源項目巔峰人生等欄目。 showImg(https://segmentfault.com/img/remote/1460000013279448); 前端每周清單第 51 期: React Context A...
閱讀 1644·2021-11-24 09:39
閱讀 3083·2021-11-22 15:24
閱讀 3091·2021-10-26 09:51
閱讀 3277·2021-10-19 11:46
閱讀 2891·2019-08-30 15:44
閱讀 2217·2019-08-29 15:30
閱讀 2537·2019-08-29 15:05
閱讀 773·2019-08-29 10:55