响应式布局 àì夳堔傛蜴生んèń 2022-07-11 08:14 319阅读 0赞 <table style="height:40px; border-color:#a9a9a9; border-width:0px; background-color:#a9a9a9; width:100%"> <tbody> <tr> <td><span style="font-size:18px; color:#ffffff"><strong>一、概述</strong></span></td> </tr> </tbody> </table> 响应式设计,用一句话概括就是针对任意设备对网页内容进行完美布局的一种显示机制。利用HTML5和CSS3就更加如虎添翼。 HTML5强调简化标签,例如文档类型声明,在HTML5中,仅用<!DOCTYPE html>即可,链接外部脚本、样式文件,也更加宽松,无需type属性,如下: <script src='Monkey.js'></script> *代替-->* <script src='Monkey.js' type='text/javascript'></script> 同时,HTML5新增了语义化标签元素,易读和利于SEO,如下: \--<section>元素用来定义文档或应用程序中的区域。 \--<nav>元素用来定义文档的主导航区域 \--<article>元素用来包裹独立的内容片段。 \--<aside>元素用来表示与页面主内容松散相关内容。 \--<header>、<footer>、<address>、<hgroup> 而CSS3,根据其新特性,则可代替JavaScript,实现一些动画效果,轻量级且易于维护。 响应式设计结合了CSS3媒体查询、流式布局和弹性图片技术,下面就一起来看看。 <table style="height:40px; border-color:#a9a9a9; border-width:0px; background-color:#a9a9a9; width:100%"> <tbody> <tr> <td><span style="font-size:18px; color:#ffffff"><strong>二、CSS3</strong><strong>媒体查询</strong></span></td> </tr> </tbody> </table> CSS3媒体查询,就是由媒体类型(screen和print)和一个或多个检测媒体特性的条件表达式组成,可以在不改变页面内容的情况下,为特定的一些输出设备定制显示效果。 媒体查询中常用媒体特性,如下: \--width:视口宽度; \--height:视口高度; \--device-width:设备屏幕宽度; \--device-height:设备屏幕高度; \--orientation:检查设备处于横向还是纵向; \--aspect-ratio:基于视口宽度和高度比; 以上特性,都可使用min和max前缀来创建一个查询范围。 举例,当屏幕中视口宽度小于960像素时,如下CSS代码生效: /*CSS样式表中使用媒体查询*/ @media screen and (max-width: 960px){ body{ background-color:grey; … } } /*CSS外部链接中使用媒体查询*/ <link rel=”stylesheet” media=”screen and (max-width:960px)” href=”monkey.css”/> **PS:**为了阻止移动浏览器自动调整页面大小,我们还得使用meta,定义如下: <meta name="viewport" content="width=device-width, initial-scale=1.0"/> content里的内容就是告诉浏览器页面的宽度应该等于设备宽度。 <table style="height:40px; border-color:#a9a9a9; border-width:0px; background-color:#a9a9a9; width:100%"> <tbody> <tr> <td><span style="font-size:18px; color:#ffffff"><strong>三、流式布局</strong></span></td> </tr> </tbody> </table> 媒体查询,威力无穷,但是它的局限性也很明显,在媒体查询设置的不同断点,CSS样式只会从一组突变到另一组,样式之间没有任何平滑渐变。 因此,我们引入“流式布局”来弥补媒体查询的短板。 流式布局,又叫百分比布局,顾名思义就是使用百分比来代替固定像素的宽度,两者之间怎么转化呢? *公式如下:* 目标元素宽度 / 上下文元素宽度 = 百分比宽度 例如,现有html代码如下: <body> <div id="wrapper"> <header> <nav> <ul> <li>navigation1</li> <li>navigation2</li> </ul> </nav> </header> </div> </body> 固定像素样式如下: * { margin: 0; padding: 0; } #wrapper { margin: 0 auto; width: 960px; background: grey; } header { margin-right: 10px; margin-left: 10px; width: 940px; } nav { padding-top: 20px; padding-bottom: 20px; width: 940px; } nav ul li { display: inline-block; list-style-type: none; } 现在,我们将样式中的宽度、水平方向的内外边距,利用上面公式转换成百分比,如下: *PS:假设我们以1000像素的视口为基准。* /*目标元素宽度 / 上下文元素宽度 = 百分比宽度*/ * { margin: 0; padding: 0; } #wrapper { margin: 0 auto; width: 96%;/* 960 / 1000 = 96% */ background: grey; } header { margin-right: 1.041667%;/* 10 / 960 = 1.041667% */ margin-left: 1.041667%;/* 10 / 960 = 1.041667% */ width: 97.916667%;/* 940 / 960 = 97.916667% */ } nav { padding-top: 20px; padding-bottom: 20px; width: 100%;/* 940 / 940 = 100% */ } nav ul li { display: inline-block; list-style-type: none; } 在上述CSS样式中,我们换算百分比,之所以保留如此多位数,是为了更加精确。 此外,我们还可以将像素级文字,转换成相对单位—em。上述转换公式同样适用于将文字的像素单位转换为相对单位。 不过,值得注意的是,现代浏览器的默认文字大小都是16像素(显示声明除外),因此一开始给body标签应用如下任何一条规则所产生的效果都是一样的: font-size: 100%; font-size: 16px; font-size: 1em; <table style="height:40px; border-color:#a9a9a9; border-width:0px; background-color:#a9a9a9; width:100%"> <tbody> <tr> <td><span style="font-size:18px; color:#ffffff"><strong>四、弹性图片</strong></span></td> </tr> </tbody> </table> 在现代浏览器中要实现图片随着流动布局相应缩放非常简单,只需在CSS中作如下声明,即可: img { max-width: 100%; } 这样就可以使图片自动缩放到与其容器100%匹配。更进一步,可以将同样的样式应用到其他多媒体标签上,使其也可以自动缩放,如下: img, object, video, embed { max-width: 100%; }
相关 响应式布局 一、响应式开发 1.1、概述 就是使用媒体查询针对不同宽度的设备进行布局和样式的设置,从而适配不同设备的目的。 1.2、响应式布局容器 1 落日映苍穹つ/ 2023年10月14日 11:07/ 0 赞/ 95 阅读
相关 响应式布局 (给前端大全加星标,提升前端技能) > 作者:浪里行舟 > > https://github.com/ljianshu/Blog/issues/38 前言 柔光的暖阳◎/ 2023年08月17日 16:34/ 0 赞/ 191 阅读
相关 响应式布局。 响应式布局:[http://caibaojian.com/356.html][http_caibaojian.com_356.html] ①设置 Meta 标签 大多数移 待我称王封你为后i/ 2023年07月01日 08:55/ 0 赞/ 46 阅读
相关 响应式布局 目录: 1. 响应式布局介绍 2. 响应式布局特点 3. 响应式布局的实现方式 4. 响应式布局媒体查询使用 5. 响应式布局示例 1. 示例1 快来打我*/ 2022年10月18日 01:38/ 0 赞/ 383 阅读
相关 响应式布局 <table style="height:40px; border-color:a9a9a9; border-width:0px; background-color:a9a9a àì夳堔傛蜴生んèń/ 2022年07月11日 08:14/ 0 赞/ 320 阅读
相关 响应式布局 一、视口(viewport) 移动前端的viewport就是浏览器中用于呈现网页的区域。视口通常并不等于屏幕大小。手机端和PC端视口存在差异,电脑端视口等于其分辨率,手机端的 迈不过友情╰/ 2022年03月31日 10:54/ 0 赞/ 373 阅读
相关 响应式布局 4.1 meta 标签 最简单的处理方式是加上一个 meta 标签 <meta name="viewport" content="width=device-width, 左手的ㄟ右手/ 2022年03月09日 10:06/ 0 赞/ 386 阅读
相关 响应式布局 响应式布局 响应式布局在面对不同分辨率设备灵活性强,在平时的网页设计中基本上都要用到响应式布局设计,它给我们提供了良好的用户浏览页面,能带给我们更好的客户体验,下面给大家分享 本是古典 何须时尚/ 2022年01月29日 00:47/ 0 赞/ 389 阅读
相关 响应式布局 简介 什么是响应式布局? 同一个页面在不同屏幕尺寸下有不同的布局 传统的开发方式是PC端开发一套,手机一套 使用响应式布局只需要开发一套 以你之姓@/ 2022年01月20日 10:47/ 0 赞/ 438 阅读
相关 响应式布局 一、什么是响应式布局? 响应式布局就是一个网站能够兼容多个终端——而不是为每个终端做一个特定的版本。这个概念是为解决移动互联网浏览而诞生的。 响应式布局可以为不 浅浅的花香味﹌/ 2021年12月22日 20:17/ 0 赞/ 423 阅读
还没有评论,来说两句吧...