如何实现响应式布局

首先,响应式布局可以让网站同时适配不同分辨率和不同的手机端,让客户有更好的体验。

方案一:

利用对属性设置百分比来适配不同屏幕,注意这里的百分比是相对于父元素; 能够设置的属性有 width、height、padding、margin,其他属性比如 border、font-size 不能用百分比设置的,先看一个简单例子:

在这里插入图片描述在这里插入图片描述

顶部是利用设置图片 width: 50%来适应不同的分辨率,由于原始图片高度不同,所以第一张图片顶部会有空白,这种情况最好两张图片宽高保持一致,如果使用强制高度统一,会导致图片变形;
注意:当屏幕大于图片的宽度时,会进行拉伸;解决拉伸方法就是改为
max-width: 50%,但当屏幕大于图片的宽度时,两边会有空白。栏目是利用设置单栏目 width: 25%来适应不同的分辨率。
由于没办法对 font-size 进行百分比设置,所以用的最多就是对图片和大块布局进行百分比设置。

方案二:使用媒体查询 (CSS3 @media 查询)

利用媒体查询设置不同分辨率下的css 样式,来适配不同屏幕,先看一个简单例子:

在这里插入图片描述
三个不同分辨率下显示对应的背景色。
媒体查询相对于百分比布局,可以对布局进行更细致的调整,但需要在每个分辨率下面都写一套 css 样式;分辨率拆分可视项目具体情况而定。
注意:IE6、7、8 不支持媒体查询。

方案三.rem 响应式布局

当前页面中元素的rem 单位的样式值都是针对于html 元素的font-size 的值进行动态计算的,所以有两种方法可以达到适配不同屏幕:
第一种利用媒体查询,在不同分辨率下给 html 的 font-size 赋值。第二种利用 js 动态计算赋值,详细代码如下图:

在这里插入图片描述
缺点就是打开页面时候,元素大小会有一个变化过程。

方案四.vw 响应式布局

根据 PSD 文件宽度或高度作为标准,元素单位 px 转换为 vw 或 vh,比如font-size: 12px,PSD 文件宽度 375,转换公式 12 * 100 / 375,则样式改为font-size: 3.2vw,下面是我经常使用的工具,有利于提高转换效率。

在这里插入图片描述

现阶段手机端用的最多就是这个方法,能保持不同屏幕下元素显示效果一致, 也不用写多套样式。

方案五.flex 弹性布局

利用 flex 属性来适配不同屏幕,下图利用简单的属性实现栏目响应式

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
响应式布局是一种能够根据设备屏幕大小和分辨率自动调整页面布局的技术。CSS是实现响应式布局的关键工具之一。下面是一些常用的CSS技术和方法来实现响应式布局: 1. 媒体查询(Media Queries):使用媒体查询可以根据不同的设备屏幕大小应用不同的CSS样式。通过在CSS中定义不同的媒体查询规则,可以根据屏幕宽度、高度、设备类型等条件来应用不同的样式。 2. 弹性盒子布局(Flexbox):Flexbox是一种弹性布局模型,可以方便地创建灵活的、自适应的布局。通过设置容器和子元素的flex属性,可以实现自动调整元素的大小和位置。 3. 网格布局(Grid Layout):网格布局是一种二维布局系统,可以将页面划分为行和列,并通过设置网格单元格的大小和位置来实现布局。网格布局提供了更精确的控制,适用于复杂的布局需求。 4. 相对单位(Relative Units):使用相对单位(如百分比、em、rem等)可以根据父元素或根元素的大小来设置元素的尺寸。相对单位可以使元素相对于其容器进行自适应调整。 5. 图片和媒体的响应式处理:通过设置max-width属性和width:auto,可以使图片和媒体元素根据容器大小自动调整大小,避免溢出或变形。 6. 隐藏和显示元素:通过设置display属性或使用CSS伪类(如:visible和:hidden)可以根据屏幕大小来隐藏或显示特定的元素,以适应不同的设备。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值