CSS3中的Media Queries学习笔记
建站知识 2021-07-03 08:15www.168986.cn长沙网站建设
一、Media Queries 支持的属性
二、关键字
and - 结合多个媒体查询 not - 排除某种制定的媒体类型 only - 用来定某种特定的媒体类型
三、引用样式示例
CSS Code复制内容到剪贴板
- <link rel="stylesheet" media="all" href="style.css" />
- <link rel="stylesheet" media="screen and (min-width:980px)" href="desk.css" />
- <link rel="stylesheet" media="screen and (min-width:768px) and (max-width:980px)" href="pad.css" />
- <link rel="stylesheet" media="screen and (min-width:480) and (max-width: 768px)" href="phone.css" />
- <link rel="stylesheet" media="screen and (max-width:320px)" href="small.css" />
四、内联样式示例
CSS Code复制内容到剪贴板
- @media screen and (min-width: 980px) {
- //css code
- }
- @screen and (min-width:768px) and (max-width:980px) {
- //css code
- }
- @screen and (min-width:480) and (max-width: 768px) {
- //css code
- }
- @screen and (max-width:320px) {
- //css code
- }
- @media screen and (max-device-width: 480px) {
- //max-device-width等于480px
- }
- @media screen and (device-aspect-ratio: 16/9), screen and (device-aspect-ratio: 16/10) {
- //设备宽高比
- }
- @media all and (orientation:portrait) {
- //竖屏
- }
- @media all and (orientation:landscape) {
- //横屏
- }
五、I8的兼容性问题解决
问题根源
在项目的CSS文件中采用了media这东东来根据视窗的大小自动调整布局,,IE8及以下版本浏览器不支持CSS3 media queries,也就是@media screen and (max-width: 900px) 里面的css代码没有执行,
CSS Code复制内容到剪贴板
- @media screen and (max-width: 900px) {
- ...
- }
这如何是好啊,网上倒是有不少人提出解决方法,最简单的方法就是
IE8和之前的浏览器不支持CSS3 media queries,你可以在页面中添加css3-mediaqueries.js来解决这个问题。
XML/HTML Code复制内容到剪贴板
- <!--[if lt IE 9]>
- <script src="http://css3-mediaqueries-js.googlecode./svn/trunk/css3-mediaqueries.js"></script>
- <![endif]-->
原来如此,还挺简单嘛,结果大失所望啊,项目中怎么试怎么就不行呢,还望试过可行的同仁点拨点拨啊,没办法只能采用另一种稍微复杂些的方法,也是从网上学来,这里要考虑两个问题,一是只有IE8及其低版本才做此处理,二是只有浏览器缩小到某一个大小范围后才做此处理。方法如下
原理采用jquery,其实不懂,会用就行,然后在html中根据需要来改变对应的CSS文件
解决方法
在所有页面的共用js文件后面添加如下代码
JavaScript Code复制内容到剪贴板
- /Adjust the layout in IE8 and lower than IE8 when the browser is narrow/
- function processLowerIENavigate()
- {
- var isIE = document.all ? 1 : 0;
- if (isIE == 1)
- {
- if(navigator.userAgent.indexOf("MSIE7.0") > 0 || navigator.userAgent.indexOf("MSIE 8.0") > 0)
- {
- // var doc=document;
- var link=document.createElement("link");
- link.setAttribute("rel", "stylesheet");
- link.setAttribute("type", "text/css");
- link.setAttribute("id", "size-stylesheet");
- link.setAttribute("href", "");
- var heads = document.getElementsByTagName("head");
- if(heads.length)
- heads[0].appendChild(link);
- else
- document.documentElement.appendChild(link);
- document.write("<script type='text/javascript' src='jquery.min.js'></script>");
- document.write("<script type='text/javascript' src='media_screen.js'></script>");
- }
- }
- }
- var lowerIE8 = processLowerIENavigate();
- media_screen.js文件内容如下,直接从网上copy
- function adjustStyle(width) {
- width = parseInt(width);
- if (width < 902) {
- //alert("<900");
- //alert(width);
- $("#size-stylesheet").attr("href", "navigateLowerIE8.css");
- } else {
- // alert(">900");
- //alert(width);
- $("#size-stylesheet").attr("href", "");
- }
- }
- $(function() {
- adjustStyle($(this).width());
- $(window).resize(function() {
- adjustStyle($(this).width());
- });
- });
navigateLowerIE8.css文件就是IE8其低版本浏览器在缩小时的页面布局了。OK,一切都确实搞定。
长沙网站设计
- 如何自己建一个网站 自己想建个网站,怎么建
- 如何制作网站免费建站 创建网站免费注册
- html简单网页代码 html简单网页代码超链接
- dreamweaver网页制作 dreamweaver网页制作模板
- 上海网站建设 上海网站建设制作微信
- 如何制作网站和网页 如何制作一个网页
- html网页制作代码大全 端午节html网页制作代码大
- app开发公司 app开发公司前十名
- html网页制作 html网页制作文字居中
- app制作一个需要多少钱 请人制作一个app多少钱
- 成都网站制作 成都网站制作维护
- 百度建一个网站多少钱 百度做个公司网站要多少
- html+css网页制作成品 web网页制作成品css+javascrip
- html网页制作案例 html网页设计案例
- html+css网页制作成品 web网页制作成品css+javascrip
- 个人网站模板 个人网站模板HTML