媒体查询 android,媒体查询

Media Queries

自适应阶段

自从有了不同屏幕的尺寸,我们就开始尝试自适应了

居中

虽然不能让所有屏幕都自适应,但是可以利用居中让元素看起来在同一位置

.center{

width: 990px;

margin: 0 auto;

height: 200px;

line-height: 200px;

}

百分比

同样可以利用百分比让DOM结构适应屏幕

.container{

border-top: solid 1px #666;

border-left: solid 1px #666;;

}

.item{

display: inline-block;

width: 33%;

height: 200px;

border-right: solid 1px #666;

border-bottom: solid 1px #666;

background: orange;

box-sizing: border-box;

}

浮动

对于宽度不一的,我们可以利用浮动做到一定程度的自适应

.container{

overflow: hidden;

padding: 20px;

}

.item{

float: left;

padding: 8px 12px;

border: solid 1px #1686cc;

}

响应式

终于等来了CSS3的Media Queries,可以让我们针对不同的设备场景使用不同的CSS

CSS 2

实际上在很早之前,CSS就支持媒体查询了

页面有些部分需要在打印的时候隐藏或者变大,这时候可以使用media使某些style只在打印的时候生效

@media print {

/* 适用于印刷的样式 */

}

常用的媒体类型有

1\. all(所有),适用于所有设备。

2\. handheld(手持),用于手持设备。

3\. print(印刷),用于分页材料以及打印预览模式下在屏幕上的文档视图。

4\. projection(投影),用于投影演示文稿,例如投影仪。

5\. screen(屏幕) ,主要用于计算机屏幕。

在使用的时候可以在样式表直接书写 @media指令+空格+媒体类型(多个逗号隔开)

@media print {

body { font-size: 10pt }

}

@media screen {

body { font-size: 13px }parsing-errors

}

@media screen, print {

body { line-height: 1.2 }

}

CSS 3

但是CSS 2的媒体类型应用场景极为有限,CSS3大大拓展了这一能力

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

.container{

background: orange;

}

}

当媒体类型匹配且表达式为真的时候,对应style就会其作用,除非使用not或者only操作符,否则媒体类型不是必需的,默认代表所有媒体类型。

操作符

and

and操作符用于将多个media feature组合成一个查询,同时用于组合media type 和media feature,一个基本的media query类似这样,一个meidia feature作用于所有media type

@media (min-width: 700px) { ... }

但是如果只想在横向显示时应用就可以使用and操作符把media type和media feature结合起来

@media (min-width: 700px) and (orientation: landscape) { ... }

这样上面的media query只有在可视窗口(viewport)最小是700px并且是横向显示的时候才返回true,如果还想进一步限制设备为tv可以这样

@media tv and (min-width: 700px) and (orientation: landscape) { ... }

逗号分隔的列表

在使用逗号分隔的查询列表中每个查询都被视为一个独立的查询,任何本查询中的作用符不影响其他查询,只要有一个查询返回true,style就会被作用。

举例来说,如果希望特定style在viewport最小宽度为700px或手持式设备上生效,可以这么写:

@media (min-width: 700px), handheld and (orientation: landscape) { ... }

not

not操作符作用域整个查询,所以只有在整个查询返回false的情况下使用not后才会返回true。当使用逗号分隔的列表的时候not作用于邻近的查询,而不会作用于每个查询

@media not all and (monochrome) { ... }

查询其实会这样起作用

@media not (all and (monochrome)) { ... }

而不是这样

@media (not all) and (monochrome) { ... }

对于逗号分隔的列表

@media not screen and (color), print and (color)

查询是这样子的

@media (not (screen and (color))), print and (color)

only

only操作符用于阻止不支持带有media feature的media queries的浏览器应用特定style

media features

有以下常用的media feature

width:浏览器宽度

height:浏览器高度

device-width:设备屏幕分辨率的宽度值

device-height:设备屏幕分辨率的高度值

orientation:浏览器窗口的方向纵向还是横向,当窗口的高度值大于等于宽度时该特性值为portrait,否则为landscape

aspect-ratio:比例值,浏览器的纵横比

device-aspect-ratio:比例值,屏幕的纵横比

color:设备使用多少位的颜色值,如果不是彩色设备,值为0

color-index:色彩表的色彩数

monochrome:单色帧缓冲器每个像素的字节

resolution:分辨率值,设备分辨率值

scan:电视机类型设备扫描方式,progressive或interlace

grid:只能指定两个值0或1,是否基于栅格的设备

如何引入media

有两种常用的引入方式

link方法引入

@media引入

@media screen and (min-width: 600px) and (max-width: 800px){

选择器{

属性:属性值;

}

}

浏览器兼容性

3e46d4808e44

image

应用

For iPhone 4

For iPad

移动设备iPad上的Safari和在iPhone上的是相同的,只是他们不同之处是iPad声明了不同的方向,比如说上面的例子,在纵向(portrait)时采用portrait.css来,在横向(landscape)时采用landscape.css。

For Android

/*240px的宽度*/

/*360px的宽度*/

/*480px的宽度*/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值