手机
当前位置:查字典教程网 >网页设计 > Div+Css教程 >利用css @viewport 做设备适配
利用css @viewport 做设备适配
摘要:在需要调整设备浏览器的viewport时,我们通常在HTML中使用来解决。但是令人意想不到的是,viewportmeta标签并不具有&ldq...

在需要调整设备浏览器的viewport时,我们通常在HTML中使用来解决。但是令人意想不到的是,viewport meta标签并不具有“规范性”,即它不是W3C的正式标准,也非Web标准。

Apple公司率先在其iPhone中的Safari浏览器中实现了viewport meta标签,其他浏览器厂商也快速采纳了它。由于IOS、Android及类似平台在平板电脑和智能手机设备中的流行度和市场占有率,使得viewport meta标签被广泛使用。

viewport meta标签是用做布局的,这种活本应属于CSS的职能。这也是为什么W3C正在尝试规范一种新的设备适配方法的原因,将HTML对viewport的控制转交给CSS。

@viewport CSS 规则

使用@viewport规则控制viewport,与使用meta标签的效果相同,只是我们完全使用CSS来控制。与使用meta标签一样,仍然建议使用设备无关的值(device-width)来设置viewport宽度。

@viewport {

width: device-width;

}

如今,也有很多开发者已经在使用@viewport了,因为在IE10的捕捉模式(snap mode)下,Windows 8 Metro模式下的一个特性,可以将浏览器拖至屏幕的左端或右端,同时使用两个窗口。奇怪的是, 要解决这个问题,开发者就要使用上面介绍的device-width方法,或者在media query里面使用@viewport规则。

@viewport 与 Media Queries配合使用

我们可以在media query里面使用@viewport,已达到更加精准的优化。比如,下面的media query将viewport小于400px(IE10 的 捕捉模式)缩放至320px宽。

@media screen and (max-width: 400px) {

@-ms-viewport { width: 320px; }

...

}

@viewport 描述符(Descriptors)

zoom描述符等同于viewport meta 标签的initial-sacale属性。

@viewport {

width: device-width;

zoom: 2;

}

与minimum-scale, maximum-scale对应的描述符是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 标签。

后记

用此方法可以解决 Windows Phone IE浏览下, 定位在底部(bottom:0)的元素与底部有间距的问题。

参考:

Thinking Ahead: CSS Device Adaptation With @viewport http://getbootstrap.com/getting-started/#browsers Windows Phone 8 and Device-Width

【利用css @viewport 做设备适配】相关文章:

十套非常漂亮的CSS3按钮样式 无需图片

利用CSS的Clip属性来创造多彩文字

CSS让ul所有的li居中显示的方法

网页制作:使用css设置iframe样式

div层调整z-index属性无效情况处理

CSS盒模型制定网页的宽度和高度的原理

利用CSS同比例缩小图片技巧

教你制作完美的Favicon图标

CSS条状图表形式的实现方法

如何用!important解决浏览器兼容性问题

精品推荐
分类导航