aboutsummaryrefslogtreecommitdiff
path: root/files/zh-tw/learn/performance/多媒體/index.html
blob: cbd3d8e23a1d3afcdc8960714f45a42b43897bea (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
---
title: '多媒體: 圖像跟影片'
slug: Learn/Performance/多媒體
translation_of: Learn/Performance/Multimedia
---
<p>媒體,換句話說就是圖像跟影片,平均占了網站超過70%的下載流量。以下載的效能來考慮的話,減少媒體數量和檔案大小是一個簡單可以實現的目標。 <span class="seoSummary">這篇文章聚焦在優化圖像跟影片來改善網站的效能。</span></p>

<div class="blockIndicator note">
<p>這是一篇進階的在 web 上優化多媒體的介紹,包含基本的原則還有技巧,想了更多的話,可以看  <a href="https://images.guide">https://images.guide</a></p>
</div>

<h2 id="為什麼要優化你的多媒體">為什麼要優化你的多媒體</h2>

<p>對於平均的網站, <a href="https://discuss.httparchive.org/t/state-of-the-web-top-image-optimization-strategies/1367">51% 的頻寬消耗來自圖像, 而影像則是 25%</a>,所以我們可以說處理和優化你的多媒體是很重要的。</p>

<p>你必須考慮流量的使用. 很多的人都是使用流量有限制的上網方案, 或是用多少付多少的上網方案,也就是根據用了多少 MB 來付費。這樣的問題不是只發生在新興國家的市場. 在 2018 年, <a href="https://www.ofcom.org.uk/__data/assets/pdf_file/0021/113169/Technology-Tracker-H1-2018-data-tables.pdf" rel="noopener">英國仍有 24% 在使用「用多少付多少」的方案</a></p>

<p>你還需要考慮記憶體的問題,因為許多移動設備的 RAM 都有限。有一件很重要的事你必須要記住,下載的圖像是被儲存在記憶體裡的。</p>

<h2 id="優化圖像傳送">優化圖像傳送</h2>

<p>儘管是頻寬的最大消耗者,但因為圖像是非同步載入的,所以訪問者可以在下載的同時看到頁面。因此,它們對<a href="/en-US/docs/Learn/Performance/perceived_performance">感知性能的影響</a>遠低於許多人的預期。 然而,圖像在內容中很常被使用,因此,重要的應該是讓訪問者盡快地看到它們,以獲得良好的體驗。</p>

<h3 id="載入策略">載入策略</h3>

<p>對於大多數網站來說,最大改進之一是將不在視窗裡的圖像做 lazy-loading ,而不是在初始頁面載入時就全部下載下來,不管訪問者是否之後會往下滾動查看它們。 許多 JavaScript 函式庫都可以為你實現這個功能,例如說 lazysize,並且瀏覽器的供應商也正在著手原生的 <code>lazyload</code> 屬性,然而目前還處於實驗階段。</p>

<p>除了載入圖像的子集之外,接下來您還應該研究一下圖像本身的格式:</p>

<ul>
 <li>你是否正在載入最佳格式? (見下文)</li>
 <li>你載入的尺寸正確嗎?</li>
 <li>你已經壓縮圖像了嗎? (查看 <a href="https://imageoptim.com/" rel="noopener">ImageOptim</a>)</li>
</ul>

<h4 id="最佳格式">最佳格式</h4>

<p>這非常值得用一個章節來介紹。因為為圖像選擇正確的格式可能很棘手。格式通常取決於圖像的用途:</p>

<ul>
 <li><strong>Progressive JPEG</strong>—不需要移動卷軸就能看到的網頁圖像。</li>
 <li><strong>WebP / JPEG-XR / JPEG2000</strong>—往下移動卷軸才能看到網頁圖像。</li>
 <li><strong>PNG / WebP</strong>—有透明度的圖像。 </li>
 <li><strong>SVG</strong>—向量圖, 圖示 (備註: SVGs 比 icon fonts 還要好得多!).</li>
</ul>

<p>優先在不需要移動卷軸就能看到的網頁區域使用 Progressive JPEG 的原因是因為它們會逐漸地進行渲染(因此得名),這意味著用戶可以先看到低解析度的版本,然後再逐漸地變得清晰。而不是從頂部一行一行的以最高解析度來載入圖像,或甚至只有在完全下載好後才顯示。</p>

<h4 id="控制下載圖像的優先級別(和順序)">控制下載圖像的優先級別(和順序)</h4>

<p>將最重要的圖像更早地呈現在訪問者面前,可以改善感知性能。</p>

<p>第一件要確認的事情是,你的前景圖像標籤 <code>&lt;img /&gt;</code> 跟你定義在 CSS 裡 <code>background-image</code> 的背景圖像 — 前景圖像比背景圖像被賦予更高的優先級別。</p>

<p>其次,通過採用優先級別提示,你可以在圖像標籤中添加<code>importance</code> 屬性來進一步控制優先級別。輪播是一個在圖像上使用優先級別提示的例子,它的第一個圖像的優先級高於其他的圖像。</p>

<h3 id="渲染策略">渲染策略</h3>

<p>由於圖像是非同步載入的,並且會在第一次渲染後繼續載入,因此,如果在載入之前未定義尺寸的話,則可能會導致頁面內容的重新編排。比如說,當圖像載入時,文字內容可能會被擠壓到下面。所以, 很重要的是,定義 <code>width</code> 跟 <code>height</code> 或是新的 <code>intrinsicsize</code> 屬性。</p>

<p>對於任何的背景圖像,設置 <code>background-color</code> 的值非常重要,因為在圖像下載之前,它能讓上面的內容是能夠被閱讀的。</p>

<h2 id="優化影像傳送">優化影像傳送</h2>

<p>為了確保您不會將不必要的大文件發送給用戶,最好<a href="#compress"> 壓縮所有你要傳輸的影像</a><a href="#omptimize">優化<code>&lt;source&gt;</code> 順序</a>, 設定 <a href="https://developer.mozilla.org/en-US/docs/Learn/Performance/Multimedia#Video_autoplay">autoplay</a><a href="#muted">移除靜音影像的聲音</a>, <a href="https://developer.mozilla.org/en-US/docs/Learn/Performance/Multimedia#Video_preload">優化影像預載</a>, 還有 <a href="https://developer.mozilla.org/en-US/docs/Learn/Performance/Multimedia#Consider_streaming">考慮串流</a> 這部影像。</p>

<h3 id="壓縮所有影像">壓縮所有影像</h3>

<p>大多數的影像壓縮工作都包含,比較影像裡的相鄰幀,並刪除原始幀和後續幀中相同的細節。你想同時壓縮影像並將其匯出為多種影像格式, 包含 WebM,MPEG-4/H.264,以及 Ogg/Theora.</p>

<p>你用來創建影像的軟體可能包含優化檔案大小的功能。如果沒有的話,那麼可以考慮幾種線上工具,像是之後篇章會討論的 <a href="https://www.ffmpeg.org/">FFmpeg</a>,他可以協助編碼,解碼,轉換,以及呈現其他神奇的功能。</p>

<h3 id="優化_&lt;source>_順序">優化 <code>&lt;source&gt;</code> 順序</h3>

<p>從最小到最大來排序影像的來源。例如說,給定三個壓縮影像,分別為 10 MB,12MB,以及13MB, 把最小的擺在第一個,最大的擺在最後一格。</p>

<pre>&lt;video width="400" height="300" controls="controls"&gt;
  &lt;!-- WebM: 10 MB --&gt;
  &lt;source src="video.webm" type="video/webm" /&gt;
  &lt;!-- MPEG-4/H.264: 12 MB --&gt;
  &lt;source src="video.mp4" type="video/mp4" /&gt;
  &lt;!-- Ogg/Theora: 13 MB --&gt;
  &lt;source src="video.ogv" type="video/ogv" /&gt;
&lt;/video&gt;</pre>

<p>就順序的角度來說,瀏覽器會下載它看到的第一個影像來源,因此先讓他載入一個較小的影像。就"最小"的角度來說,要確認你的壓縮影響仍然看起來不會太糟。有幾個演算法可能會讓你的影像看起來像是個會動的 gif 。雖然 128 Kb 的影像可能在用戶體驗上會比 10 MB 的影像好,可是把看起來像是 gif 粒狀的影像放在內容後面,也可能會對你的品牌產生負面影響。</p>

<p>查看 <a href="http://caniuse.com/#search=video">CanIUse.com</a> 來確認現今瀏覽器對於影像以及不同媒體格式的支持。  </p>

<h3 id="影像自動播放">影像自動播放</h3>

<p>為了確保循環播放背景影像,你需要向影像標籤裡添加多個屬性: <code>autoplay</code>, <code>muted</code>, 以及 <code>playsinline.</code></p>

<pre>&lt;video autoplay="" loop="" muted="true" playsinline="" src="backgroundvideo.mp4"&gt;</pre>

<p>雖然屬性 <code>loop</code> 和 <code>autoplay</code> 在對於影像的循環跟自動播放很合理,可是 <code>muted</code> 屬性在行動裝置的瀏覽器裡是必須添加的。</p>

<p><code>Playsinline</code> 在行動裝置裡的 Safari 是必須的,他讓影像可以在不需要全螢幕的模式下被播放。</p>

<h3 id="移除靜音影像的聲音">移除靜音影像的聲音</h3>

<p>如果你有一個 <code>hero-video</code> 或是其他靜音影片, 請將聲音從影像中移除。 </p>

<pre>&lt;video autoplay="" loop="" muted="true" playsinline="" id="hero-video"&gt;
  &lt;source src="banner_video.webm"
          type='video/webm; codecs="vp8, vorbis"'&gt;
  &lt;source src="web_banner.mp4" type="video/mp4"&gt;
&lt;/video&gt;</pre>

<p>這段 <code>hero-video</code> 代碼, 常出現在許多研討會網站以及公司的主頁, 它是個包括自動播放,循環播放和靜音的影像。它不包含任何控制選單,因此無法收聽聲音。通常它是沒有聲音的,但仍然存在音軌,因此它仍會消耗頻寬。然而,我們沒有理由將頻寬分給靜音影像的聲音。移除聲音可以節省 20% 的頻寬。這代表,如果你的影像是 10 MB,則節省了 2 MB。</p>

<p>根據您的影像創作軟體,你也許可以在匯出和壓縮過程中刪除聲音。 如果沒有,那麼有一個免費的工具 <a href="https://www.ffmpeg.org/">FFmpeg</a> ,可以使用以下指令來為你完成此任務</p>

<pre><a href="https://www.ffmpeg.org/">ffmpeg</a> -i original.mp4 -an -c:v copy audioFreeVersion.mp4</pre>

<p><code>FFmpeg</code> 稱自己為"用於記錄,轉換和串流音頻和影像的完整,跨平台解決方案"。</p>

<h3 id="影像預載">影像預載</h3>

<p>preload 屬性具有3個可用選項:<code>auto</code>|<code>metadata</code>|<code>none</code>。預設選項是 <code>metadata</code>.</p>

<p>將選項更改為 <code>auto</code> 會告訴瀏覽器自動下載整個影像。僅有在極有可能播放時才應該執行此操作,否則會浪費大量的頻寬。</p>

<p><code>preload="metadata"</code> 最多可讓 3% 的影像在頁面加載時被下載。 然後對於較大的影像來說,這可能或是大量的頻寬。</p>

<p><code>preload="none"</code> 不會在播放之前下載任何的影像。 這會延遲影像的啟動時間,但能夠為播放可能性較低的影像保存大量的頻寬。</p>

<h3 id="考慮串流">考慮串流</h3>

<p><a href="https://www.smashingmagazine.com/2018/10/video-playback-on-the-web-part-2/">串流影像讓適當的影像大小和頻寬</a> (根據網路速度) 被傳遞給用戶。 就像使用響應式圖像一樣,正確大小的影像將被傳遞到瀏覽器,從而確保用戶的快速影像啟動、低緩衝以及優化的播放。</p>