一、媒体类型
媒体类型(Media Type)在CSS2中是一个常见的属性,也是一个非常有用的属性,可以通过媒体类型对不同的设备指定不同的样式。
在CSS2中常碰到的就是all(全部)、screen(屏幕)、print(页面打印或打印预览模式),其实媒体类型远不止这三种,W3C总共列出了10种媒体类型。如下表所示:
值 |
设备类型 |
All |
所有设备 |
Braille |
盲人用点字法触觉回馈设备 |
Embossed |
盲文打印机 |
Handheld |
便携设备 |
|
打印用纸或打印预览视图 |
Projection |
各种投影设备 |
Screen |
电脑显示器 |
Speech |
语音或音频合成器 |
Tv |
电视机类型设备 |
Tty |
使用固定密度字母栅格的媒介,比如电传打字机和终端 |
其中Screen、All和Print为最常见的三种媒体类型
二、媒体引入
常见的有:link标签、@import和CSS3新增的@media几种:
link方法
link方法引入媒体类型其实就是在<link>标签引用样式的时候,通过link标签中的media属性来指定不同的媒体类型。如下所示。
<link rel="stylesheet" type="text/css" href="style.css" media="screen" /> <link rel="stylesheet" type="text/css" href="print.css" media="print" />
@import方法
@import可以引用样式文件,同样也可以用来引用媒体类型。@import引入媒体类型主要有两种方式,一种是在样式中通过@import调用另一个样式文件;另一种方法是在<head></head>标签中的<style></style>中引入,但这种使用方法在IE6~7都不被支持
在样式文件中调用另一个样式文件时,就可以指定对应的媒体类型:
@importurl(reset.css) screen; @importurl(print.css) print;
在<head>中的<style>标签中引入媒体类型方法:
<head> <style type="text/css"> @importurl(style.css) all; </style> </head>
@media方法
@media是CSS3中新引进的一个特性,被称为媒体查询。在页面中也可以通过这个属性来引入媒体类型。@media引入媒体类型和@import有点类似也具有两方式。
(1)在样式文件中引用媒体类型:
@media screen { 选择器{/*你的样式代码写在这里…*/} }
(2)使用@media引入媒体类型的方式是在<head>标签中的<style>中引用。
<head> <style type="text/css"> @media screen{ 选择器{/*你的样式代码写在这里…*/} } </style> </head>
css3 Media Queries使用方法
Media Queries是CSS3新增加的一个模块功能,其最大的特色就是通过CSS3来查询媒体,然后调用对应的样式,Media Queries能在不同的条件下使用不同的样式,使页面在不同在终端设备下达到不同的渲染效果
Media Queries的使用方法如下:
@media 媒体类型and (媒体特性){你的样式}
注意:使用Media Queries必须要使用“@media”开头,然后指定媒体类型(也可以称为设备类型),随后是指定媒体特性(也可以称之为设备特性)。媒体特性的书写方式和样式的书写方式非常相似,主要分为两个部分,第一个部分指的是媒体特性,第二部分为媒体特性所指定的值,而且这两个部分之间使用冒号分隔
1. 最大宽度max-width
“max-width”是媒体特性中最常用的一个特性,其意思是指媒体类型小于或等于指定的宽度时,样式生效。如:
@media screen and (max-width:480px){ .ads { display:none; } }
上面表示的是:当屏幕小于或等于480px时,页面中的广告区块(.ads)都将被隐藏
2. 最小宽度min-width
“min-width”与“max-width”相反,指的是媒体类型大于或等于指定宽度时,样式生效。
@media screen and (min-width:900px){ .wrapper{width: 980px;} }
上面表示的是:当屏幕大于或等于900px时,容器“.wrapper”的宽度为980px。
3. 多个媒体特性使用
Media Queries可以使用关键词"and"将多个媒体特性结合在一起。也就是说,一个Media Query中可以包含0到多个表达式,表达式又可以包含0到多个关键字,以及一种媒体类型。
当屏幕在600px~900px之间时,body的背景色渲染为“#f5f5f5”,如下所示。
@media screen and (min-width:600px) and (max-width:900px){ body {background-color:#f5f5f5;} }
4. 设备屏幕的输出宽度Device Width
在智能设备上,例如iPhone、iPad等,还可以根据屏幕设备的尺寸来设置相应的样式(或者调用相应的样式文件)。同样的,对于屏幕设备同样可以使用“min/max”对应参数,如“min-device-width”或者“max-device-width”。
<link rel="stylesheet" media="screen and (max-device-width:480px)" href="iphone.css" />
上面的代码指的是“iphone.css”样式适用于最大设备宽度为480px,比如说iPhone上的显示,这里的“max-device-width”所指的是设备的实际分辨率,也就是指可视面积分辨率
5. not关键词
使用关键词“not”是用来排除某种制定的媒体类型,也就是用来排除符合表达式的设备。换句话说,not关键词表示对后面的表达式执行取反操作,如:
@media not print and (max-width: 1200px){样式代码}
上面代码表示的是:样式代码将被使用在除打印设备和设备宽度小于1200px下所有设备中
6. only关键词
only用来指定某种特定的媒体类型,可以用来排除不支持媒体查询的浏览器。其实only很多时候是用来对那些不支持Media Query但却支持Media Type的设备隐藏样式表的。其主要有:支持媒体特性的设备,正常调用样式,此时就当only不存在;表示不支持媒体特性但又支持媒体类型的设备,这样就会不读样式,因为其先会读取only而不是screen;另外不支持Media Queries的浏览器,不论是否支持only,样式都不会被采用。如
<linkrel="stylesheet" media="only screen and (max-device-width:240px)" href="android240.css" />
在Media Query中如果没有明确指定Media Type,那么其默认为all,如:
<linkrel="stylesheet" media="(min-width:701px) and (max-width:900px)" href="mediu.css" />
另外在样式中,还可以使用多条语句来将同一个样式应用于不同的媒体类型和媒体特性中,指定方式如下所示。
<linkrel="stylesheet" type="text/css" href="style.css" media="handheld and (max-width:480px), screen and (min-width:960px)" />
上面代码中style.css样式被用在宽度小于或等于480px的手持设备上,或者被用于屏幕宽度大于或等于960px的设备上。
到目前为止,CSS3 Media Queries得到了众多浏览器支持,除了IE6-8浏览器不支持之外,在所有现代浏览器中都可以完美支持。还有一个与众不同的时,Media Queries在其他浏览器中不要像其他CSS3属性一样在不同的浏览器中添加前缀
可以把这些样式加到你的样式文件中,或者单独创建一个名为“responsive.css”文件,并在相应的条件中写上你的样式,让他适合你的设计需求:
1.1024px显屏
@media screen and (max-width : 1024px) { /* 样式写在这里 */ }
2.800px显屏
@media screen and (max-width : 800px) { /* 样式写在这里 */ }
3.640px显屏
@media screen and (max-width : 640px) { /* 样式写在这*/ }
4.iPad横板显屏
@media screen and (max-device-width: 1024px) and (orientation: landscape) { /* 样式写在这 */ }
5.iPad竖板显屏
@media screen and (max-device-width: 768px) and (orientation: portrait) { /* 样式写在这 */ }
6.iPhone 和 Smartphones
@media screen and (min-device-width: 320px) and (min-device-width: 480px) { /* 样式写在这 */ }
<div class="wrapper">
<div class="left"></div>
<div class="content"></div>
</div>
.wrapper{
width: 100%;
background: green;
max-width: 980px;
overflow: hidden;
margin-left: auto;
margin-right: auto;
}
.left {
float: left;
width: 20%;
background: orange;
min-height: 100px;
}
.content {
float: right;
width: 78%;
background: blue;
min-height: 100px;
}
@media (max-width: 320px) {
.wrapper {
min-width: 320px;
width: 98%;
margin-left: 1%;
margin-right: 1%;
}
.left {
float: none;
width: 100%;
}
.content{
float: none;
width: 100%;
}
}
相关推荐
在网页设计中,CSS3的媒体查询(Media Queries)是一项强大的技术,它允许我们根据设备的特性,如屏幕尺寸、分辨率、颜色深度等,来应用不同的样式。然而,老版本的Internet Explorer(IE6-8)并不支持这一特性,这...
**CSS3媒体查询**是CSS3中的一个重要特性,它允许内容根据设备的物理特性,如宽度、高度、分辨率甚至颜色深度来呈现。这使得设计师可以创建多布局设计,适应不同类型的设备,包括手机、平板电脑和桌面电脑。媒体查询...
CSS3媒体查询(Media Queries)是现代网页设计中不可或缺的一部分,它允许我们根据设备特性,如屏幕尺寸、分辨率、方向等,为不同的设备提供适当的样式。然而,IE8及以下版本的浏览器并不支持CSS3媒体查询,这在构建...
在网页设计领域,CSS3 Media Queries是现代网页布局的关键特性,它允许我们根据设备特性,如屏幕尺寸、分辨率和方向,来应用不同的样式。然而,不幸的是,Internet Explorer 8(IE8)及其更低版本并不支持这个功能。...
通过定义不同屏幕尺寸下的样式规则,我们可以针对不同分辨率的设备应用不同的CSS样式。例如: ```css @media screen and (max-width: 600px) { /* 在600px及以下宽度的设备上应用的样式 */ } ``` 3. **...
3. **CSS3 Background Properties** 在CSS中,我们使用`background`属性或者其子属性(如`background-image`、`background-size`、`background-position`、`background-repeat`)来设置背景视频。其中,`background...
3. **媒体查询**:响应式设计的关键在于媒体查询(`media queries`),它允许根据设备特性(如屏幕尺寸、分辨率等)来应用不同的样式,从而实现网页在不同设备上的良好展示。 4. **边框与背景**:CSS3允许使用圆角...
5. **JavaScript交互**:尽管CSS3可以实现很多视觉效果,但按钮的动态行为,如点击后的反馈,通常需要JavaScript来处理。可以添加事件监听器(如`addEventListener`),当按钮被点击时触发相应的函数。在这个炫酷...
4. SVG矢量图:支持创建高质量的图形,适合在不同分辨率的设备上显示。 5. Geolocation API:获取用户地理位置信息,为本地化服务和地图应用提供便利。 6. Web Storage:包括localStorage和sessionStorage,用于在...
3. **编写CSS**:在CSS中正常引入背景图片,Loader会自动处理。 4. **生成Sprite**:Webpack编译后,会生成Sprite图像和更新过的CSS文件,其中包含指向Sprite图像的新背景定位信息。 ### 注意事项与扩展 - **兼容性...
这些资源可能是为了帮助开发者理解如何利用CSS3的特性,如媒体查询(Media Queries)、Flexbox或Grid布局来适配不同屏幕尺寸,特别是针对iPhone6的375px * 667px分辨率。 【标签】由于没有提供具体的标签,我们可以...
4. 响应式设计:考虑到盲文点阵可能需要在不同设备上显示,开发者可能会运用CSS3的媒体查询和响应式设计原则,确保在不同屏幕尺寸和分辨率下都能正确显示。 5. ARIA(无障碍富互联网应用程序)属性:为了让视障用户...
CSS3引入了媒体查询(Media Queries),这是实现响应式设计的核心工具。通过媒体查询,我们可以根据设备的特定条件,如宽度、高度、方向等,应用不同的样式规则。例如: ```css @media screen and (max-width: 600...
虽然上述方法可以实现基本的功能需求,但在现代Web开发中,还有更多高效且灵活的方式来处理不同分辨率的样式调整: 1. **媒体查询**:使用CSS3中的媒体查询来根据不同屏幕尺寸应用不同的样式规则,无需额外的...
3. **媒体查询**:Media Queries是响应式设计的核心,用于根据设备特性(如屏幕尺寸、分辨率和方向)应用不同的样式,确保网站在不同设备上都能良好显示。 4. **CSS动画与过渡**:通过`@keyframes`规则创建自定义...
lib-flexible的核心思想是利用JavaScript动态计算设备像素比(DPR),进而调整页面元素的大小,以达到在不同分辨率和屏幕尺寸下良好的显示效果。 一、lib-flexible的原理 lib-flexible库主要由两部分组成:...
CSS3 的媒体查询允许我们在 CSS 文件中定义针对不同设备特性的样式规则。例如: ```css /* 适用于小于等于600px宽度的设备 */ @media screen and (max-width: 600px) { /* 在这里编写适用于小屏幕的样式 */ } /* ...
需要注意的是,当使用预处理语言时,`px2rem-loader`可能无法处理嵌套规则或某些特定情况,这时`postcss-plugin-px2rem`会更全面。同时,适配过程中,可能会遇到某些库或组件内部的px单位不被转换的问题,这时可以...
8. 兼容性处理:虽然现代浏览器对CSS3支持良好,但仍然需要关注老版本浏览器的兼容性问题。可以利用特性检测库或条件注释来为不支持CSS动画的浏览器提供备选方案。 9. 可维护性和可复用性:将加载动画封装为独立的...