zoukankan      html  css  js  c++  java
  • CSS3 多媒体查询:查找设备的类型,CSS3 根据设置自适应显示

    CSS3 多媒体查询


    CSS2 多媒体类型

    @media 规则在 CSS2 中有介绍,针对不同媒体类型可以定制不同的样式规则。

    例如:你可以针对不同的媒体类型(包括显示器、便携设备、电视机,等等)设置不同的样式规则。

    但是这些多媒体类型在很多设备上支持还不够友好。


    CSS3 多媒体查询

    CSS3 的多媒体查询继承了 CSS2 多媒体类型的所有思想: 取代了查找设备的类型,CSS3 根据设置自适应显示。

    媒体查询可用于检测很多事情,例如:

    • viewport(视窗) 的宽度与高度
    • 设备的宽度与高度
    • 朝向 (智能手机横屏,竖屏) 。
    • 分辨率

    目前很多针对苹果手机,Android 手机,平板等设备都会使用到多媒体查询。


    浏览器支持

    表格中的数字表示支持该属性的第一个浏览器的版本号。

    属性     
    @media 21.0 9.0 3.5 4.0 9.0

    多媒体查询语法

    多媒体查询由多种媒体组成,可以包含一个或多个表达式,表达式根据条件是否成立返回 true 或 false。

    @medianot|onlymediatypeand (expressions) {CSS 代码...; }

    如果指定的多媒体类型匹配设备类型则查询结果返回 true,文档会在匹配的设备上显示指定样式效果。

    除非你使用了 not 或 only 操作符,否则所有的样式会适应在所有设备上显示效果。

    • not: not是用来排除掉某些特定的设备的,比如 @media not print(非打印设备)。

    • only: 用来定某种特别的媒体类型。对于支持Media Queries的移动设备来说,如果存在only关键字,移动设备的Web浏览器会忽略only关键字并直接根据后面的表达式应用样式文件。对于不支持Media Queries的设备但能够读取Media Type类型的Web浏览器,遇到only关键字时会忽略这个样式文件。

    • all: 所有设备,这个应该经常看到。

    你也可以在不同的媒体上使用不同的样式文件:

    <linkrel="stylesheet" media="mediatypeand|not|only (expressions)" href="print.css">

    CSS3 多媒体类型

    描述
    all 用于所有多媒体类型设备
    print 用于打印机
    screen 用于电脑屏幕,平板,智能手机等。
    speech 用于屏幕阅读器

    多媒体查询简单实例

    使用多媒体查询可以在指定的设备上使用对应的样式替代原有的样式。

    以下实例中在屏幕可视窗口尺寸小于 480 像素的设备上修改背景颜色:

    实例

    @media screen and (min- 480px) {
        body {
            background-color: lightgreen;
        }
    }

    以下实例在屏幕可视窗口尺寸大于 480 像素时将菜单浮动到页面左侧:

    实例

    @media screen and (min- 480px) {
        #leftsidebar { 200px; float: left;}
        #main {margin-left:216px;}
    }
  • 相关阅读:
    Android开发经验一判断当前屏幕是全屏还是非全屏
    Android得到控件在屏幕中的坐标
    MyBatis简单的增删改查以及简单的分页查询实现
    Coreseek:第二步建索引及測试
    极静之渊
    统计电影票房排名前10的电影并存入还有一个文件
    AAA
    FreeLink开源呼叫中心设计思想
    树后台数据存储(採用webmethod)
    [乐意黎原创] 百度统计这个坑爹货
  • 原文地址:https://www.cnblogs.com/peijz/p/12703023.html
Copyright © 2011-2022 走看看