原文出處:http://www.uisdc.com/images-and-videos-responsive-website
@陳子木?:響應式網(wǎng)頁設計,是一種正在流行的網(wǎng)頁開發(fā)思想,它是利用靈活可變的柵格系統(tǒng),令網(wǎng)頁的顯示模式可以根據(jù)訪問設備的屏幕尺寸規(guī)格而進行自適應。預計2015年的時候,移動端的用戶數(shù)量將會從目前的8億,增長到19億,而這也意味著目前我們?yōu)樽烂鏋g覽器而設計的網(wǎng)頁,將會在他們的手機和平板上呈現(xiàn)出非常糟糕的使用體驗。
但是隨著實際應用狀況的改變,響應式網(wǎng)頁設計還是會出現(xiàn)一系列復雜的并發(fā)癥。本文余下的部分,就是詳細闡述如何在響應式網(wǎng)頁中安置和處理多媒體元素,諸如圖片和視頻,最終的目的是幫你做出一個靠譜的網(wǎng)站,能讓這些元素無縫地在各種手持設備上加載運行,提升用戶體驗。
先說說響應式圖片的處理方法。在響應式網(wǎng)頁設計中,圖片處理的問題或多或少地和傳統(tǒng)網(wǎng)頁中的導航欄設計有相似之處。隨著新的移動設備的普及,更高像素密度的屏幕使得網(wǎng)頁的任何一個瑕疵都顯得無比明顯,因此,圖片處理的核心問題在于如何確保網(wǎng)站(尤其是圖片)的各個方面都能盡可能靈活,并且確保每個像素不會在高分屏下模糊。
圖片顯示的問題
首先,當網(wǎng)頁對設備響應時,并不存特定的圖片發(fā)布標準。并且針對這一問題,有大量的可選方案供你選擇。不過,這個時候,問題出現(xiàn)了:3G模式下,在視網(wǎng)膜屏幕下的移動設備上圖像應該如何處理。在網(wǎng)速較差的情況下,圖片的尺寸大小是否應該自動優(yōu)化(降低)?這就是所謂“美術(shù)設計”的問題。網(wǎng)站提供的圖片在不同屏幕的設備上都能夠顯示,還是遠遠不夠的。小屏幕設備的用戶可能完全看不清圖片的細節(jié),那么,就應該在“能正常顯示”的基礎上,為這塊小屏幕單獨裁剪一個版本,讓用戶看清細節(jié)。
有人提出,開發(fā)者應該將所有不同尺寸大小比例的圖片都預先上傳到網(wǎng)站頁面中,并且設置好CSS與媒體查詢功能,將過大或過小的圖片都隱藏起來,讓瀏覽器就下載像素完全匹配的圖像。然而,實際狀況并非如此,瀏覽器在加載CSS類之前,就已經(jīng)將所有的相關圖片都下載下來,這使得網(wǎng)頁更加臃腫,加載時間更長。
圖片問題可能的解決方案
在繼續(xù)探討之前,先明確一點:讓每塊屏幕都完美顯示圖片的解決方案是不存在的??墒俏覀兡軌虿粩嗵剿骺尚行愿叩姆桨?,盡可能地提高精度,以下是我們?yōu)轫憫骄W(wǎng)頁的圖像問題,找到的可能的解決方案:
如果你開始設計一個響應式網(wǎng)站,但是對于如何操作毫無頭緒,那么你應該試試BootStrap的CSS框架。借助Bootstrap,你可以很容易達成目標。更重要的是,Bootstrap提供的樣式以及在基礎的HTML元素上擴展出的類,將會使得圖片的響應更容易實現(xiàn)。
Focal Point是一個框架,可以幫助你“種植”圖片并且控制焦點。這項技術(shù)僅僅使用了CSS,開發(fā)者僅僅需要向?qū)獦撕炛刑砑雍心繕藞D片的類就可以了。
如果加載時間是你需要考慮的首要因素的話(它應該是),那么你可以選擇CSS 精靈,尤其當你需要適配帶有視網(wǎng)膜屏幕的設備之時。當你為高分辨率屏幕適配網(wǎng)頁的時候(比如蘋果的Retina屏幕),一般會添加更大尺寸的圖片資源,并且使用CSS中的Media Query來識別并適配尺寸。但是如此一來,文件數(shù)量和大小會急劇增加,并且會增加代碼中的CSS選擇器的數(shù)量,引用更多的文件。
如果使用CSS 精靈的話,這種情況會得以改善。你可以將網(wǎng)頁所需要的圖片都包含到一張大圖中供選擇器來引用。僅僅需要一個http請求,你就可以將多個圖片素材獲取到本地。通過標簽引用的照片類素材并不適宜于用CSS精靈來處理,但是你在header和footer中使用的圖標素材和按鈕樣式之類的東西會在CSS精靈的加持下,好用很多。
自適應圖片的解決方案可以通過檢測設備的屏幕尺寸,為html嵌入符合屏幕尺寸需求的圖片資源。這種方案是一個典型的服務器端解決方案,它需要在被本地運行Javascript來檢測,但它最主要還是依靠Apache2 網(wǎng)絡服務器,PHP 5.x以及GD庫。
自適應圖片的方案最贊的地方在于你不需要改變標記。有人認為基于標記的解決方案是最好的,但是事實并非如此。對于Wordpress這樣的內(nèi)容管理系統(tǒng),自適應圖片的解決方案與之結(jié)合起來會方便很多。
如果想讓你的網(wǎng)站能圖片自適應,那么你需要在服務器端修改或者增加.htaccess文件。此外,你還需要在你的網(wǎng)站服務器的根目錄下增加一個PHP文件,并且在網(wǎng)站頁面中增加JavaScript代碼。當你做好這一切之后,PHP腳本會獲取對于圖片的任何需求,并且會根據(jù)需求所指定的斷點調(diào)整好尺寸輸出網(wǎng)頁。
在Wordpress網(wǎng)站中輸出響應式圖片的插件
在Wordpress站點中,還有其他通過插件來實現(xiàn)響應式圖片的解決方案。以下插件與??標簽的作用相同:
此外,網(wǎng)上還有很多響應式的Wordpress主題可供用戶選擇。
處理圖片的終極方案?
再強調(diào)一次,請千萬記住,所有的這些處理圖片的可行性方案都有其局限性。比如自適應圖片的方案,它需要Apache和PHP的結(jié)合,因此它用于內(nèi)容管理還好,但是不大可能完美適配于網(wǎng)站平臺或者主機服務器上。此外,自適應圖片有賴于服務器通過.htaccess文件獲取圖片尺寸的需求,這也就意味著,獲取的圖片不在自己的服務器上,.htaccess中的腳本就無能為力了。此外,這個腳本還無法檢測帶寬,如果你拿著3G版iPad Air訪問這類網(wǎng)站的話,加載速度可能會慘不忍睹。最重要的是,它并沒有解決上述的“美術(shù)設計”的問題,它僅僅只是調(diào)整了原有圖片的尺寸而已。所以,對于這一切,你需要通過試驗找出最合適的方案。
毫無疑問,對于網(wǎng)站而言視頻是極其重要的營銷工具。因此,對于富有彈性的響應式視頻的需求越來越多。
就像圖片一樣,讓圖片靈活地適配網(wǎng)頁也是個頭疼的事情。這并不關乎視頻播放器的尺寸,但即使是播放按鈕這樣的的基礎網(wǎng)頁元素,也都需要針對千奇百怪的設備來適配和優(yōu)化。以下提供幾個解決方案:
為Wordpress中的視頻優(yōu)化
雖然wordpress提供了諸多響應式的主題,但是一般情況下,這些內(nèi)嵌視頻并不會根據(jù)屏幕尺寸自行適配。這也是為何它們所在的網(wǎng)頁可能會出現(xiàn)拉伸,或者不對稱的情況。FitVids這一插件完美的解決了這個問題。這是一個jQuery插件,它能讓視頻針對屏幕尺寸自行適配。激活插件之后,Wordpress會在發(fā)布視頻內(nèi)容時,向CSS選擇器中自動添加“.post”類。保存修改,你可以嘗試在不同尺寸的設備中觀察網(wǎng)頁的布局,感受視頻播放的體驗,看看它是怎么工作的。
此外,還有更多可選的Wordpress插件:
從其他網(wǎng)站中手動嵌入視頻
YouTube以及其他類似的視頻托管網(wǎng)站通常以像素為單位固定寬度和高度,并且嵌入到代碼中。對于普通網(wǎng)站,這并沒有什么不妥,但是對于響應式網(wǎng)頁,這樣的視頻是不合用的。這些使用了內(nèi)置頁框和對象標簽的視頻網(wǎng)站代碼,用HTML5的視頻元素來處理是不可能的。簡單的說,HTML5的標簽搞不定來自Youtube和Vimeo的嵌入視頻。
這個時候,CSS再次派上了用場。具體來說,即使容器元素按比例縮小,你可又可以保持視頻的內(nèi)在比例。這種技術(shù)可以幫助你講youtube、Vimeo和SlideShare等流媒體網(wǎng)站的視頻嵌入到網(wǎng)頁中并自然地顯示。你所要做的,是使用容器來嵌入代碼,并指定子元素的絕對位置,這會使得嵌入的視頻根據(jù)屏幕寬度自動擴展。
值得注意的是,剝離出視頻并且按照尺寸比例封裝到Div的過程并不簡單,此外,這項技術(shù)對于多視頻的網(wǎng)站可行性并不高。不過如果你的網(wǎng)站已經(jīng)設計成響應式的頁面,那么這項技術(shù)將會在你的網(wǎng)站上完美運行。
接下來是一些實際案例,這些響應式網(wǎng)站針對不同瀏覽器和屏幕優(yōu)化了圖片和視頻:
案例1:BootStrap+jQuery
這是一個風格極簡的博客/作品集網(wǎng)站,它使用了Bootstrap v2.2.2和jQuery。前者讓這個網(wǎng)站可以使用大量的表單、模態(tài)、提示、按鈕、轉(zhuǎn)盤并且響應式輸出,加入jQuery之后網(wǎng)站的流布局能力又得以提升。jQuery可以讓網(wǎng)站實現(xiàn)各種不同的顯示方式(比如在桌面端瀏覽器上顯示三欄,在平板上顯示一欄,在手機屏幕上顯示一欄)。
案例2:FitVids
這是一個在Wordpress框架中通過FitVids來嵌入視頻的案例。使用這一插件的好處在于安裝方便,并且會讓視頻完美適配屏幕。
案例3:Focal Point
這一案例使用Focal point 來調(diào)整背景圖片并且突出人物照片。因此,這個案例中的網(wǎng)頁設計師并沒有提供一系列不同尺寸的圖片,他們僅僅只是改變了網(wǎng)站的視覺重心,將焦點移動到最大的物體上。
案例4:自適應圖片
更多建議: