浅谈html5 响应式布局


Posted in HTML / CSS onDecember 24, 2014

一、什么是响应式布局?

      响应式布局是Ethan Marcotte在2010年5月份提出的一个概念,简而言之,就是一个网站能够兼容多个终端——而不是为每个终端做一个特定的版本。

      这个概念是为解决移动互联网浏览而诞生的。响应式布局可以为不同终端的用户提供更加舒适的界面和更好的用户体验,而且随着目前大屏幕移动设备的普及,用大势所趋来形容也不为过。

 随着越来越多的设计师采用这个技术,我们不仅看到很多的创新,还看到了一些成形的模式。

二、响应式布局有哪些优点和缺点?

  优点:

面对不同分辨率设备灵活性强
能够快捷解决多设备显示适应问题
  缺点:

兼容各种设备工作量大,效率低下
代码累赘,会出现隐藏无用的元素,加载时间加长
其实这是一种折衷性质的设计解决方案,多方面因素影响而达不到最佳效果
一定程度上改变了网站原有的布局结构,会出现用户混淆的情况
 

三、响应式布局该怎么设计?

1、 如何解决不同设备间的兼容问题?

       CSS3中的Media Query(媒介查询)可以解决这个问题。

2、media query能够获取哪些值?

         设备的宽和高device-width,device-heigth显示屏幕/触觉设备。

              渲染窗口的宽和高width,heigth显示屏幕/触觉设备。

              设备的手持方向,横向还是竖向orientation(portrait|lanscape)和打印机等。

              画面比例aspect-ratio点阵打印机等。

              设备比例device-aspect-ratio-点阵打印机等。

              对象颜色或颜色列表color,color-index显示屏幕。

              设备的分辨率resolution

     3、语法结构及用法

              语法:@media 设备名 only (选取条件) not (选取条件) and(设备选取条件),设备二{sRules}

          用法:

               a、示例一:在link中使用@media:

                       <link rel="stylesheet" type="text/css" media="only screen and (max-width: 480px),only screen and (max-device-width: 480px)" href="link.css" rel="external nofollow" />

                      上面使用中only可省略,限定于计算机显示器,第一个条件max-width是指渲染界面最大宽度,第二个条件max-device-width是指设备最大宽度。

              b、在样式表中内嵌@media:

复制代码
代码如下:

@media (min-device-width:1024px) and (max-width:989px),screen and (max-device-width:480px),(max-device-width:480px)
and (orientation:landscape),(min-device-width:480px) and (max-device-width:1024px) and (orientation:portrait) {srules}

        设置了电脑显示器分辨率(宽度)大于或等于1024px(并且最大可见宽度为989px);屏宽在480px及其以下手持设备;屏宽在480px以及横向(即480尺寸平行于地面)放置的手持设备;

        屏宽大于或等于480px小于1024px以及                     垂直放置设备的css样式。

   四、实现响应式布局

复制代码
代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<!-- 必须加这句话
width – viewport的宽度
height – viewport的高度
initial-scale – 初始的缩放比例
minimum-scale – 允许用户缩放到的最小比例
maximum-scale – 允许用户缩放到的最大比例
user-scalable – 用户是否可以手动缩放
-->
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<!--最后对于在IE浏览器中不支持media query的情况,我们可以使用Media Query JavaScript来解决,
只需要在页面头部引用css3-mediaqueries.js即可 -->
<script src="<a href="http://css3-mediaqueries-js.googlecode.com/svn/trunk/css3-mediaqueries.js"></script">http://css3-mediaqueries-js.googlecode.com/svn/trunk/css3-mediaqueries.js"></script</a>>
<title>Document</title>
<style>
/**
设计思路很简单,首先先定义在标准浏览器下的固定宽度(假如标准浏览器的分辨率为1024px,那么我们设置宽为980px),
然后用Media Query来监测浏览器的尺寸变化,当浏览器的分辨率小于1024px的时候,
则通过Media Query预设的样式表来将页面的宽度设置为百分比显示,
这样子页面的结构元素就会根据浏览器的的尺寸来进行相对应的调整。
同理,当浏览器的可视区域改变到某个值(假如为650px)的时候,
页面的结构元素根据Media Query预设的层叠样式表来进行相对应的调整。看看我们的例子:
**/
/* 当浏览器的可视区域小于980px */
@media screen and (max-width: 980px) {
#wrap {width: 90%; margin:0 auto;}
#content {width: 60%;padding: 5%;}
#sidebar {width: 30%;}
#footer {padding: 8% 5%;margin-bottom: 10px;}
}
/* 当浏览器的可视区域小于650px */
@media screen and (max-width: 650px) {
#header {height: auto;}
#searchform {position: absolute;top: 5px;right: 0;}
#content {width: auto; float: none; margin: 20px 0;}
#sidebar {width: 100%; float: none; margin: 0;}
}
/** 为了更好的显示效果,我们往往还要格式化一些CSS属性的初始值:***/
/* 禁用iPhone中Safari的字号自动调整 */
html {
-webkit-text-size-adjust: none;
}
/* 设置HTML5元素为块 */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
display: block;
}
/* 设置图片视频等自适应调整 */
img {
max-width: 100%;
height: auto;
width: auto\9; /* ie8 */
}
.video embed, .video object, .video iframe {
width: 100%;
height: auto;
}
</style>
</head>
<body>
</body>
</html>
HTML / CSS 相关文章推荐
css3实现背景模糊的三种方式
Mar 09 HTML / CSS
image-set实现Retina屏幕下图片显示详细介绍
Dec 24 HTML / CSS
关于css兼容性问题及一些常见问题汇总
May 03 HTML / CSS
css3媒体查询中device-width和width的区别详解
Mar 27 HTML / CSS
CSS3 实现穿梭星空动画
Nov 13 HTML / CSS
HTML5实现表单自动验证功能实例代码
Jan 11 HTML / CSS
Html5 localStorage入门教程
Apr 26 HTML / CSS
HTML5中的autofocus(自动聚焦)属性介绍
Apr 23 HTML / CSS
HTML5+lufylegend实现游戏中的卷轴
Feb 29 HTML / CSS
html5+css3进度条倒计时动画特效代码【推荐】
Mar 08 HTML / CSS
浅析border-radius如何兼容IE
Apr 19 HTML / CSS
HTML5基于flash实现播放RTMP协议视频的示例代码
Dec 04 HTML / CSS
HTML5进度条特效
Dec 18 #HTML / CSS
html5+svg学习指南之SVG基础知识
Dec 17 #HTML / CSS
canvas需要在标签里直接定义宽高
Dec 17 #HTML / CSS
使用canvas绘制贝塞尔曲线
Dec 17 #HTML / CSS
使用canvas绘制超炫时钟
Dec 17 #HTML / CSS
24个canvas基础知识小结
Dec 17 #HTML / CSS
html5使用canvas绘制文字特效
Dec 15 #HTML / CSS
You might like
77A一级收信机修理记
2021/03/02 无线电
PHP 正则判断中文UTF-8或GBK的思路及具体实现
2013/11/26 PHP
Thinkphp中volist标签mod控制一定记录的换行BUG解决方法
2014/11/04 PHP
Cygwin中安装PHP方法步骤
2015/07/04 PHP
PHP的中使用非缓冲模式查询数据库的方法
2017/02/05 PHP
php 猴子摘桃的算法
2017/06/20 PHP
说明你的Javascript技术很烂的五个原因
2011/04/26 Javascript
javascript中万恶的function实例分析
2011/05/25 Javascript
javascript模版引擎-tmpl的bug修复与性能优化分析
2011/10/23 Javascript
js时间日期和毫秒的相互转换
2013/02/22 Javascript
Jquery封装tab自动切换效果的具体实现
2013/07/13 Javascript
检查输入的是否是数字使用keyCode配合onkeypress事件
2014/01/23 Javascript
把字符串按照特定的字母顺序进行排序的js代码
2014/01/28 Javascript
javascript实现了照片拖拽点击置顶的照片墙代码
2015/04/03 Javascript
有关Promises异步问题详解
2015/11/13 Javascript
微信小程序 弹框和模态框实现代码
2017/03/10 Javascript
jquery 键盘事件的使用方法详解
2017/09/13 jQuery
React Native AsyncStorage本地存储工具类
2017/10/24 Javascript
Angular 作用域scope的具体使用
2017/12/11 Javascript
JS实现不用中间变量temp 实现两个变量值得交换方法
2018/02/04 Javascript
Vue路由切换时的左滑和右滑效果示例
2018/05/29 Javascript
详解Vue-axios 设置请求头问题
2018/12/06 Javascript
ES6 更易于继承的类语法的使用
2019/02/11 Javascript
wxPython使用系统剪切板的方法
2015/06/16 Python
Python简单定义与使用二叉树示例
2018/05/11 Python
windows7 32、64位下python爬虫框架scrapy环境的搭建方法
2018/11/29 Python
Python OOP类中的几种函数或方法总结
2019/02/22 Python
python 协程中的迭代器,生成器原理及应用实例详解
2019/10/28 Python
法国娇韵诗官方旗舰店:Clarins是来自法国的天然护肤品牌
2018/06/30 全球购物
编写一个 C 函数,该函数在一个字符串中找到可能的最长的子字符串,且该字符串是由同一字符组成的
2015/07/23 面试题
SOA面试题:如何在SOA中实现松耦合
2013/07/21 面试题
仓管岗位职责范本
2014/02/08 职场文书
开会通知
2015/04/20 职场文书
公务员保密工作承诺书
2015/05/04 职场文书
导游词之无锡古运河
2019/11/14 职场文书
HTML+CSS 实现顶部导航栏菜单制作
2021/06/03 HTML / CSS