>>分享Web前端开发技术,并对孙卫琴的《精通Vue.js:Web前端开发技术详解》提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 26002 个阅读者 刷新本主题
 * 贴子主题:  CSS3 多媒体查询 回复文章 点赞(0)  收藏  
作者:sunshine    发表时间:2019-08-11 18:17:50     消息  查看  搜索  好友  邮件  复制  引用

  

CSS3 多媒体查询

CSS2 多媒体类型

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

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

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

CSS3 多媒体查询

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

     媒体查询可用于检测很多事情,例如:    
  • viewport(视窗) 的宽度与高度
  • 设备的宽度与高度
  • 朝向 (智能手机横屏,竖屏) 。
  • 分辨率
     目前很多针对苹果手机,Android 手机,平板等设备都会使用到多媒体查询。            

浏览器支持

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

      
属性
@media 21.0 9.0 3.5 4.0 9.0
        

多媒体查询语法

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

     @media   not | only   mediatype   and  ( expressions )  {
       CSS  代码...;
     }

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

   除非你使用了 not 或 only 操作符,否则所有的样式会适应在所有设备上显示效果。    
  •       not: not是用来排除掉某些特定的设备的,比如 @media not print(非打印设备)。    
  •       only: 用来定某种特别的媒体类型。对于支持Media Queries的移动设备来说,如果存在only关键字,移动设备的Web浏览器会忽略only关键字并直接根据后面的表达式应用样式文件。对于不支持Media Queries的设备但能够读取Media Type类型的Web浏览器,遇到only关键字时会忽略这个样式文件。    
  •       all: 所有设备,这个应该经常看到。    
      你也可以在不同的媒体上使用不同的样式文件:

            < link   rel =" stylesheet "  media =" mediatype   and | not | only  ( expressions )"  href =" print .css ">

CSS3 多媒体类型

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

多媒体查询简单范例

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

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

范例

@media screen and (min-width: 480px) {
     body {

background-color:  lightgreen;
    }
}

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

范例

@media screen and (min-width: 480px) {
     #leftsidebar { width:  200px;  float:  left;}
     #main { margin-left: 216px;}
}

程序猿的技术大观园:www.javathinker.net



[这个贴子最后由 flybird 在 2020-03-07 12:49:26 重新编辑]
  Java面向对象编程-->多线程(下)
  JavaWeb开发-->自定义JSP标签(Ⅰ)
  JSP与Hibernate开发-->数据库事务的并发问题的解决方案
  Java网络编程-->基于MVC和RMI的分布式应用
  精通Spring-->通过Axios访问服务器
  Vue3开发-->计算属性和数据监听
  webpack常用插件
  javaScript中"=="和"==="运算符的区别
  web前端工程师面试题的知识考点盘总
  Vue选项的用法
  20分钟带你掌握JavaScript Promise和 Async/Await
  js Worker 线程收集1~9999的之间所有质数;Worker线程交换数...
  拯救React的hooks:react的问题和hooks的作用
  Vue.js学习笔记-基础部分+完整实现代码
  Vue路由开启keep-alive时的注意点
  一看就懂得移动端rem布局、rem如何换算
  AJAX获取服务器响应
  jQuery 效果:隐藏和显示
  JavaScript的HTML DOM MenuItem 对象
  JavaScript中的HTML DOM Label 对象
  HTML中插入脚本的用法
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。