CSS3中的Media Queries学习笔记


Posted in HTML / CSS onMay 23, 2016

一、Media Queries 支持的属性
CSS3中的Media Queries学习笔记

CSS3中的Media Queries学习笔记

二、关键字
and - 结合多个媒体查询 not - 排除某种制定的媒体类型 only - 用来定某种特定的媒体类型

三、引用样式示例

CSS Code复制内容到剪贴板
  1. <link rel="stylesheet" media="all" href="style.css" />   
  2. <link rel="stylesheet" media="screen and (min-width:980px)" href="desktop.css" />   
  3. <link rel="stylesheet" media="screen and (min-width:768px) and (max-width:980px)" href="pad.css" />   
  4. <link rel="stylesheet" media="screen and (min-width:480) and (max-width: 768px)" href="phone.css" />   
  5. <link rel="stylesheet" media="screen and (max-width:320px)" href="small.css" />  

四、内联样式示例

CSS Code复制内容到剪贴板
  1. @media screen and (min-width980px) {   
  2.     //css code  
  3. }   
  4. @screen and (min-width:768px) and (max-width:980px) {   
  5.     //css code  
  6. }   
  7. @screen and (min-width:480) and (max-width768px) {   
  8.     //css code  
  9. }   
  10. @screen and (max-width:320px) {   
  11.     //css code  
  12. }   
  13.   
  14. @media screen and (max-device-width480px) {   
  15.     //max-device-width等于480px  
  16. }   
  17. @media screen and (device-aspect-ratio: 16/9), screen and (device-aspect-ratio: 16/10) {   
  18.     //设备宽高比   
  19. }   
  20. @media all and (orientation:portrait) {   
  21.     //竖屏   
  22. }   
  23. @media all and (orientation:landscape) {   
  24.     //横屏   
  25. }  

五、I8的兼容性问题解决
问题根源:
在项目的CSS文件中采用了media这东东来根据视窗的大小自动调整布局,但是,但是IE8及以下版本浏览器不支持CSS3 media queries,也就是@media screen and (max-width: 900px) 里面的css代码没有执行,

CSS Code复制内容到剪贴板
  1. @media screen and (max-width900px) {   
  2.   ...   
  3. }  

这如何是好啊,网上倒是有不少人提出解决方法,最简单的方法就是:
IE8和之前的浏览器不支持CSS3 media queries,你可以在页面中添加css3-mediaqueries.js来解决这个问题。

XML/HTML Code复制内容到剪贴板
  1. <!--[if lt IE 9]>  
  2.     <script src="http://css3-mediaqueries-js.googlecode.com/svn/trunk/css3-mediaqueries.js"></script>  
  3. <![endif]-->  

原来如此,还挺简单嘛,结果大失所望啊,项目中怎么试怎么就不行呢,还望试过可行的同仁点拨点拨啊,没办法只能采用另一种稍微复杂些的方法,也是从网上学来,这里要考虑两个问题,一是只有IE8及其低版本才做此处理,二是只有浏览器缩小到某一个大小范围后才做此处理。方法如下:
原理:采用jquery,其实不懂,会用就行,然后在html中根据需要来改变对应的CSS文件
解决方法:
在所有页面的共用js文件后面添加如下代码:

JavaScript Code复制内容到剪贴板
  1. /*Adjust the layout in IE8 and lower than IE8 when the browser is narrow*/  
  2. function processLowerIENavigate()   
  3. {   
  4.    var isIE = document.all ? 1 : 0;   
  5.    if (isIE == 1)   
  6.    {   
  7.        if(navigator.userAgent.indexOf("MSIE7.0") > 0 || navigator.userAgent.indexOf("MSIE 8.0") > 0)   
  8.        {     
  9.     //  var doc=document;    
  10.            var link=document.createElement("link");   
  11.            link.setAttribute("rel""stylesheet");   
  12.            link.setAttribute("type""text/css");   
  13.            link.setAttribute("id""size-stylesheet");   
  14.            link.setAttribute("href""");   
  15.      
  16.            var heads = document.getElementsByTagName("head");   
  17.            if(heads.length)   
  18.                heads[0].appendChild(link);   
  19.            else  
  20.                document.documentElement.appendChild(link);   
  21.   
  22.            document.write("<script type='text/javascript' src='jquery.min.js'></script>");   
  23.            document.write("<script type='text/javascript' src='media_screen.js'></script>");   
  24.      
  25.        }   
  26.    }    
  27. }   
  28. var lowerIE8 = processLowerIENavigate();   
  29.   
  30. media_screen.js文件内容如下,直接从网上copy:   
  31. function adjustStyle(width) {   
  32.     width = parseInt(width);   
  33.     if (width < 902) {   
  34. //alert("<900");   
  35. //alert(width);   
  36.         $("#size-stylesheet").attr("href""navigateLowerIE8.css");   
  37.     } else {   
  38.       // alert(">900");   
  39.   //alert(width);   
  40.        $("#size-stylesheet").attr("href""");    
  41.     }   
  42. }   
  43.   
  44. $(function() {   
  45.     adjustStyle($(this).width());   
  46.     $(window).resize(function() {   
  47.         adjustStyle($(this).width());   
  48.     });   
  49. });  

navigateLowerIE8.css文件就是IE8其低版本浏览器在缩小时的页面布局了。OK,一切都确实搞定。

HTML / CSS 相关文章推荐
CSS实现圆形放大镜狙击镜效果 只有圆圈里的放大
Dec 10 HTML / CSS
纯CSS3编写的的精美动画进度条(无flash/无图像/无脚本/附源码)
Jan 07 HTML / CSS
一款恶搞头像特效的制作过程 利用css3和jquery
Nov 21 HTML / CSS
详解CSS3中@media的实际使用
Aug 04 HTML / CSS
HTML5混合开发二维码扫描以及调用本地摄像头
Dec 27 HTML / CSS
HTML5实现QQ聊天气泡效果
Jun 26 HTML / CSS
HTML5的标签的代码的简单介绍 HTML5标签的简介
May 28 HTML / CSS
使用css如何制作时间ICON方法实践
Nov 12 HTML / CSS
HTML5引入的新数组TypedArray介绍
Dec 24 HTML / CSS
html5 canvas实现圆形时钟代码分享
Dec 25 HTML / CSS
使用jTopo给Html5 Canva中绘制的元素添加鼠标事件
May 15 HTML / CSS
Html5实现用户注册自动校验功能实例代码
May 24 HTML / CSS
详解CSS3的perspective属性设置3D变换距离的方法
May 23 #HTML / CSS
CSS3中设置3D变形的transform-style属性详解
May 23 #HTML / CSS
css 元素选择器的简单实例
May 23 #HTML / CSS
css sprite简单实例
May 23 #HTML / CSS
CSS3中的Transition过度与Animation动画属性使用要点
May 20 #HTML / CSS
CSS3制作炫酷的下拉菜单及弹起式选单的实例分享
May 17 #HTML / CSS
CSS3中各种颜色属性的使用教程
May 17 #HTML / CSS
You might like
coreseek 搜索英文的问题详解
2013/06/08 PHP
PHP中cookie和session的区别实例分析
2014/08/28 PHP
在WordPress中使用PHP脚本来判断访客来自什么国家
2015/12/10 PHP
php ajax实现文件上传进度条
2016/03/29 PHP
thinkphp3.2.3版本的数据库增删改查实现代码
2016/09/22 PHP
PHP date_default_timezone_set()设置时区操作实例分析
2020/05/16 PHP
js实现无需数据库的县级以上联动行政区域下拉控件
2013/08/14 Javascript
JQuery实现鼠标滑过显示导航下拉列表
2013/09/12 Javascript
JS 仿腾讯发表微博的效果代码
2013/12/25 Javascript
JavaScript开发人员的10个关键习惯小结
2014/12/05 Javascript
Web前端开发工具——bower依赖包管理工具
2016/03/29 Javascript
JS实现简单的tab切换选项卡效果
2016/09/21 Javascript
JS jQuery使用正则表达式去空字符的简单实现代码
2017/05/20 jQuery
vue中SPA单页面应用程序详解
2017/11/07 Javascript
浅谈vue-router 路由传参的方法
2017/12/27 Javascript
Mint UI组件库CheckList使用及踩坑总结
2018/12/20 Javascript
[58:46]OG vs NAVI 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
Django1.3添加app提示模块不存在的解决方法
2014/08/26 Python
详解django中自定义标签和过滤器
2017/07/03 Python
python计算auc指标实例
2017/07/13 Python
python3+selenium实现126邮箱登陆并发送邮件功能
2019/01/23 Python
5款Python程序员高频使用开发工具推荐
2019/04/10 Python
python面试题Python2.x和Python3.x的区别
2019/05/28 Python
python多线程与多进程及其区别详解
2019/08/08 Python
python实现简单井字棋小游戏
2020/03/05 Python
Python实现SMTP邮件发送
2020/06/16 Python
Python使用itcaht库实现微信自动收发消息功能
2020/07/13 Python
小程序瀑布流解决左右两边高度差距过大的问题
2019/02/20 HTML / CSS
美国女孩洋娃娃店:American Girl
2017/10/24 全球购物
Nike比利时官网:Nike.com (BE)
2019/02/07 全球购物
澳大利亚设计的优质鞋类和适合澳大利亚生活方式的服装:Rivers
2019/04/23 全球购物
初三化学教学反思
2014/01/23 职场文书
公司活动邀请函
2014/01/24 职场文书
学校党的群众路线教育实践活动总结报告
2014/07/03 职场文书
个人房屋租赁合同(标准范本)
2019/09/16 职场文书
Win11任务栏太宽了怎么办?一招解决Win11任务栏太宽问题
2021/11/21 数码科技