利用css @viewport 做設(shè)備適配

在需要調(diào)整設(shè)備瀏覽器的viewport時(shí),我們通常在HTML中使用來(lái)解決。但是令人意想不到的是,viewport meta標(biāo)簽并不具有“規(guī)范性”,即它不是W3C的正式標(biāo)準(zhǔn),也非Web標(biāo)準(zhǔn)。
Apple公司率先在其iPhone中的Safari瀏覽器中實(shí)現(xiàn)了viewport meta標(biāo)簽,其他瀏覽器廠商也快速采納了它。由于IOS、Android及類似平臺(tái)在平板電腦和智能手機(jī)設(shè)備中的流行度和市場(chǎng)占有率,使得viewport meta標(biāo)簽被廣泛使用。
viewport meta標(biāo)簽是用做布局的,這種活本應(yīng)屬于CSS的職能。這也是為什么W3C正在嘗試規(guī)范一種新的設(shè)備適配方法的原因,將HTML對(duì)viewport的控制轉(zhuǎn)交給CSS。
@viewport CSS 規(guī)則
使用@viewport規(guī)則控制viewport,與使用meta標(biāo)簽的效果相同,只是我們完全使用CSS來(lái)控制。與使用meta標(biāo)簽一樣,仍然建議使用設(shè)備無(wú)關(guān)的值(device-width)來(lái)設(shè)置viewport寬度。
@viewport {
width: device-width;
}
如今,也有很多開(kāi)發(fā)者已經(jīng)在使用@viewport了,因?yàn)樵贗E10的捕捉模式(snap mode)下,Windows 8 Metro模式下的一個(gè)特性,可以將瀏覽器拖至屏幕的左端或右端,同時(shí)使用兩個(gè)窗口。奇怪的是, 要解決這個(gè)問(wèn)題,開(kāi)發(fā)者就要使用上面介紹的device-width方法,或者在media query里面使用@viewport規(guī)則。
@viewport 與 Media Queries配合使用
我們可以在media query里面使用@viewport,已達(dá)到更加精準(zhǔn)的優(yōu)化。比如,下面的media query將viewport小于400px(IE10 的 捕捉模式)縮放至320px寬。
@media screen and (max-width: 400px) {
@-ms-viewport { width: 320px; }
...
}
@viewport 描述符(Descriptors)
zoom描述符等同于viewport meta 標(biāo)簽的initial-sacale屬性。
@viewport {
width: device-width;
zoom: 2;
}
與minimum-scale, maximum-scale對(duì)應(yīng)的描述符是max-zoom, min-zoom。
@viewport {
width: device-width;
max-zoom: 3;
min-zoom: 0.50;
}
user-zoom與user-scalable屬性等效。
@viewport {
width: device-width;
user-zoom: fixed;
}
瀏覽器支持情況
IE10/11 , opera, webkit, moz 都已支持,,且需要廠商前綴。
@-webkit-viewport {
width: device-width;
}
@-moz-viewport {
width: device-width;
}
@-ms-viewport {
width: device-width;
}
@-o-viewport {
width: device-width;
}
@viewport {
width: device-width;
}
所以,目前我們還是需要viewport meta 標(biāo)簽。
后記
用此方法可以解決 Windows Phone IE瀏覽下, 定位在底部(bottom:0)的元素與底部有間距的問(wèn)題。
參考:
- Thinking Ahead: CSS Device Adaptation With @viewport
- http://getbootstrap.com/getting-started/#browsers
- Windows Phone 8 and Device-Width
相關(guān)文章
像素密度與CSS3的viewport在移動(dòng)端Web響應(yīng)式布局中的運(yùn)用
viewport是CSS3中調(diào)整縮放的利器,特別適用于移動(dòng)端Web界面的操作與布局,接下來(lái)我們就來(lái)詳解像素密度與CSS3的viewport在移動(dòng)端web響應(yīng)式布局中的運(yùn)用.2016-05-27HTML5移動(dòng)端開(kāi)發(fā)中的Viewport標(biāo)簽及相關(guān)CSS用法解析
這篇文章主要介紹了HTML5移動(dòng)端開(kāi)發(fā)中的Viewport標(biāo)簽及相關(guān)CSS用法解析,Viewport常被叫做視口或視區(qū),在移動(dòng)端布局和屏幕適配中有著重要的作用,需要的朋友可以參考下2016-04-15簡(jiǎn)單總結(jié)CSS3中視窗單位Viewport的常見(jiàn)用法
這篇文章主要介紹了CSS3中視窗單位Viewport的常見(jiàn)用法,包括視窗的高度寬度及垂直居中等基本設(shè)定方法,需要的朋友可以參考下2016-02-04網(wǎng)頁(yè)寬度自動(dòng)適應(yīng)手機(jī)屏幕寬度的實(shí)現(xiàn)代碼(viewport)
這篇文章主要介紹了網(wǎng)頁(yè)寬度自動(dòng)適應(yīng)手機(jī)屏幕寬度的實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-08-11meta標(biāo)簽中的viewport控制設(shè)備屏幕css
meta標(biāo)簽中的viewport可以控制設(shè)備屏幕的高度、寬度、初始的縮放比例等等,喜歡的朋友可以了解下2014-08-22meta標(biāo)簽中的使用viewport定義屏幕css
meta標(biāo)簽中的viewport可以設(shè)置屏幕的css樣式,包括寬、高、初始縮放比例等等2014-07-28html網(wǎng)頁(yè)中meta viewport屬性說(shuō)明
這篇文章主要介紹了html網(wǎng)頁(yè)中meta viewport屬性說(shuō)明,需要的朋友可以參考下2014-05-07- 這篇文章主要介紹了html的meta viewport屬性說(shuō)明,需要的朋友可以參考下2014-04-16
HTML meta viewport屬性詳細(xì)說(shuō)明
viewport并非只是ios上的獨(dú)有屬性,在android、winphone上同樣也有viewport,下面為大家詳細(xì)介紹下HTML meta viewport2014-03-12- 隨著高端手機(jī)(Andriod,Iphone,Ipod,WinPhone等)的盛行,移動(dòng)互聯(lián)應(yīng)用開(kāi)發(fā)也越來(lái)越受到人們的重視,用html5開(kāi)發(fā)移動(dòng)應(yīng)用是最好的選擇。然而,每一款手機(jī)有不同的分辨率,不2013-12-02