什么是响应式Web设计?怎样进行?(2)

时间:2011-11-21 17:00:40 

弹性图片

响应式Web设计的思路中,一个重要的因素是怎样处理图片方面的问题。有很多同比缩放图片的技术,其中有不少是简单易行的。其中,由Richard Rutter最先尝试的一种做法比较流行,即使用CSS的max-width属性。这个方法在Ethan Marcotte的液态图片一文中也有提到。

img { max-width: 100%;}

只要没有其他涉及到图片宽度的样式代码覆盖掉这一行规则,页面上所有的图片就会以其原始宽度进行加载,除非其容器可视部分的宽度小于图片的原始宽度。上面的代码确保图片最大的宽度不会超过浏览器窗口或是其容器可视部分的宽度,所以当窗口或容器的可视部分开始变窄时,图片的最大宽度值也会相应的减小,图片本身永远不会容器边缘隐藏和覆盖。实际上,就像Jason Grigsby在他的CSS Media Query for Mobile is Fool\'s Gold一文中提到的,"液态图片背后的思路,就是无论何时,都确保在其原始宽度范围内,以最大的宽度同比完整的显示图片。我们不必在样式表中为图片设置宽度和高度,只需要让样式表在窗口尺寸发生变化时辅助浏览器对图片进行缩放。" 一种简而美的方法。

图片本身的分辨率及加载时间是另外一个需要考虑的问题。虽然通过上面的方法,可以很轻松的缩放图片,确保在移动设备的窗口中可以被完整浏览,但如果原始图片本身过大,便会显著降低图片文件的下载速度,对存储空间也会造成没有必要的消耗。

响应式图片

由Filament Group提出的"响应式图片"技术思想,有助于解决上面提到的问题:不仅要同比的缩放图片,还要在小设备上降低图片自身的分辨率。可以看下demo页面先。

这个技术的实现需要使用几个相关文件,我们可以在Github上获取。包括一个JavaScript文件(rwd-images.js),一个.htaccess文件,以及一些范例资源文件。具体使用方法可以参考Responsive Images的说明文档。大致的原理是,rwd-images.js会检测当前设备的屏幕分辨率,如果是大屏幕设备,则向页面head部分中添加BASE标记,并将后续的图片、脚本和样式表加载请求定向到一个虚拟路径"/rwd-router"。当这些请求到达服务器端,.htacces文件会决定这些请求所需要的是原始图片还是小尺寸的"响应式图片",并进行相应的反馈输出。对于小屏幕的移动设备,原始尺寸的大图片永远不会被用到。

这项技术支持多数的现代浏览器,包括IE8+、Safari、Chrome和Opera,以及这些浏览器的移动设备版本;在FireFox及一些旧浏览器中,则会优雅降级:我们仍可得到小图片的输出,但同时,原始大图也会被下载。

禁用iPhone中的图片自动缩放

在iPhone及iPod Touch中,页面会被自动的同比例缩小至最适合屏幕大小的尺寸,x轴不会产生滚动条,用户可以上下拖拽浏览全部页面,或在需要的时候放大页面的局部。这里会产生一个问题,即使我们运用响应式Web设计的思想,专门为iPhone的小屏输出小图片,它同样会随着整个页面一起被同比例缩小,如下图左侧所示。

我们可以使用苹果专有的一些meta标记来解决类似的问题。在页面的<head>部分添加以下代码(详情可以参考Think Vitamin的相关文章):

<meta name="viewport" content="width=device-width; initial-scale=1.0">

将initial-scale的值设定为"1",即可覆写默认的缩放方式,保持原始的尺寸及比例。更多关于viewport meta标记的用法,可以参考苹果官方的文档

标签:web设计,鼠标,用户
0
投稿

猜你喜欢

  • ERROR 1222 (21000): The used SELECT statements have a different number of columns

    2024-01-15 02:31:28
  • Python使用pymongo库操作MongoDB数据库的方法实例

    2023-06-04 06:20:22
  • Django choices下拉列表绑定实例

    2023-05-06 14:08:52
  • Go语言实现socket实例

    2024-02-04 20:17:30
  • Python数据类型转换实现方法

    2022-06-04 22:58:39
  • Mysql 索引 BTree 与 B+Tree 的区别(面试)

    2024-01-13 03:10:32
  • python 以16进制打印输出的方法

    2023-10-23 07:33:17
  • scrapy利用selenium爬取豆瓣阅读的全步骤

    2022-09-24 01:28:15
  • 了解不常见但是实用的Python技巧

    2022-10-12 09:07:35
  • 基于tkinter中ttk控件的width-height设置方式

    2023-07-04 21:32:20
  • Django框架反向解析操作详解

    2023-12-31 03:06:49
  • iscroll动态加载数据完美解决方法

    2024-04-10 13:59:01
  • Python编译为二进制so可执行文件实例

    2023-03-05 06:30:36
  • 浅析javascript中函数声明和函数表达式的区别

    2024-05-09 10:33:14
  • 类似google的ASP分页代码[测试通过]

    2009-03-13 12:43:00
  • 解决Python列表字符不区分大小写的问题

    2022-09-10 20:43:52
  • Python使用Kubernetes API访问集群

    2023-09-23 05:35:31
  • python3爬虫中多线程进行解锁操作实例

    2021-04-29 00:16:42
  • FSO组件之文件操作(下)

    2010-05-03 11:10:00
  • mysql查询表是否被锁的方法

    2024-01-19 13:16:41
  • asp之家 网络编程 m.aspxhome.com