热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

静态响应式布局

大家都知道响应式布局的要素有几点:1.用百分比来定位,好处是不需要用js就可以根据浏览器的缩放拉伸和缩小元素。2.用em来作为度量单位。由于是相对单位,比像素更灵活一点。虽然在我目

大家都知道响应式布局的要素有几点:

1.用百分比来定位,好处是不需要用js就可以根据浏览器的缩放拉伸和缩小元素。

2.用em来作为度量单位。由于是相对单位,比像素更灵活一点。虽然在我目前还没发现经过viewport转换后em和px用起来有什么区别 t.t

3.在HTML中为media query准备好

/*pad*/
@media screen and (min-width: 769px)
{}
/*horizontal iphone5 568x320*/
@media screen and (max-width: 768px) and (min-width: 481px)
{}
/*horizontal iphone4 480x320,large android*/
@media screen and (max-width: 480px) and (min-width: 380px)
{}
/*=====vertical iphone5 320x568,vertical iphone4 320x480 ,Android=====*/
@media screen and (max-width: 379px) and (min-width: 320px)
{}
/*-----small Android-----*/
@media screen and (max-width: 319px) and (min-width: 240px)
{}
/*further small*/
@media screen and (max-width: 239px)
{}

5.对retina屏幕需要使用2倍尺寸的图片来增加像素密度,用CSS3判断设备为retina



/* ------------- Retina ------------- */
@media only screen and (-o-min-device-pixel-ratio: 2/1),
/* Opera */
only screen and (min--moz-device-pixel-ratio: 2),
/* Firefox 16 之前 */
only screen and (-webkit-min-device-pixel-ratio: 2),
/* Webkit */
only screen and (min-resolution: 240dpi),
/* 标准 */
only screen and (min-resolution: 2dppx)
/* 标准 */
{
.mod .hd h3{
background-image
:url();
background-size
: 50% 50%;
}
}

利用background-size属性。使用100% 100%来让图片撑满,50%来缩小一倍。

有2个可选值,第1个值用于指定背景图的width,第2个值用于指定背景图的height,如果只指定1个值得,则第2个值默认为auto。

  background-size:cover; 等比扩展图片来填满元素

  background-size:contain; 等比缩小图片来适应元素的尺寸

 

另外提到一个比较神奇的属性: >background-position:center;

>它有使得背景图片自然的根据元素宽度渐渐显示并保持居中的能力,效果媲美js。

 

真正的响应式网站必定有pc乃至pad和smartphone两套设计。这样所以缩放的范围并不大,比如980到1920之间为一套。那么真正用到js缩放元素的地方也不多,多数靠css可以完成。

布局的时候往往采用一个100%宽的inline-block属性wrapper,撑满背景。然后固定宽度,比如980的block属性inner来margin:0
auto。

其他需要等比例缩放的地方可借助js完成,见我的另一篇博客 自适应全屏与居中算法

参考文章:

>响应式图片

图片液态化

CSS为Retina屏幕替换图片 


推荐阅读
  • 本文详细介绍了如何解决DNS服务器配置转发无法解析的问题,包括编辑主配置文件和重启域名服务的具体步骤。 ... [详细]
  • importpymysql#一、直接连接mysql数据库'''coonpymysql.connect(host'192.168.*.*',u ... [详细]
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ... [详细]
  • 微软推出Windows Terminal Preview v0.10
    微软近期发布了Windows Terminal Preview v0.10,用户可以在微软商店或GitHub上获取这一更新。该版本在2月份发布的v0.9基础上,新增了鼠标输入和复制Pane等功能。 ... [详细]
  • Ext JS MVC系列一:环境搭建与框架概览
    本文主要介绍了如何在项目中使用Ext JS 4作为前端框架,并详细讲解了Ext JS 4的MVC开发模式。文章将从项目目录结构、相关CSS和JS文件的引用以及MVC框架的整体认识三个方面进行总结。 ... [详细]
  • Framework7:构建跨平台移动应用的高效框架
    Framework7 是一个开源免费的框架,适用于开发混合移动应用(原生与HTML混合)或iOS&Android风格的Web应用。此外,它还可以作为原型开发工具,帮助开发者快速创建应用原型。 ... [详细]
  • 本文介绍了如何使用 CMD 批处理脚本进行文件操作,包括将指定目录下的 PHP 文件重命名为 HTML 文件,并将这些文件复制到另一个目录。 ... [详细]
  • 两个条件,组合控制#if($query_string~*modviewthread&t(&extra(.*)))?$)#{#set$itid$1;#rewrite^ ... [详细]
  • 本文详细介绍了DMA控制器如何通过映射表处理来自外设的请求,包括映射表的设计和实现方法。 ... [详细]
  • 解决Win10下MySQL连接问题:Navicat 2003无法连接到本地MySQL服务器(10061)
    本文介绍如何在Windows 10环境下解决Navicat 2003无法连接到本地MySQL服务器的问题,包括启动MySQL服务和检查配置文件的方法。 ... [详细]
  • 本文详细介绍了如何利用Duilib界面库开发窗体动画效果,包括基本思路和技术细节。这些方法不仅适用于Duilib,还可以扩展到其他类似的界面开发工具。 ... [详细]
  • Spark中使用map或flatMap将DataSet[A]转换为DataSet[B]时Schema变为Binary的问题及解决方案
    本文探讨了在使用Spark的map或flatMap算子将一个数据集转换为另一个数据集时,遇到的Schema变为Binary的问题,并提供了详细的解决方案。 ... [详细]
  • 第二十五天接口、多态
    1.java是面向对象的语言。设计模式:接口接口类是从java里衍生出来的,不是python原生支持的主要用于继承里多继承抽象类是python原生支持的主要用于继承里的单继承但是接 ... [详细]
  • 解决Parallels Desktop错误15265的方法
    本文详细介绍了在使用Parallels Desktop时遇到错误15265的多种解决方案,包括检查网络连接、关闭代理服务器和修改主机文件等步骤。 ... [详细]
author-avatar
村头的小路_157
这个家伙很懒,什么也没留下!
Tags | 热门标签
RankList | 热门文章
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有