关于rem布局和适配

之前项目中遇到的一些布局

  • 1.伸缩布局   flex 
  • 2.流式布局  百分比 
  • 3.响应布局  媒体查询 (超小屏设备的时候:流式布局)

共同点:元素只能做宽度的适配,高度不能适配(排除图片)
更好的适配方案rem:宽度和高度都能做到适配(等比缩放)

rem布局

通过控制html上的字体大小去控制页面上所有已rem为单位的基准值控制尺寸

  • 4.1 把页面上px单位转换成rem单位
  • 4.2 页面制作的时候 psd (设计稿)上的量取的px转成rem使用
  • 4.3 怎么换算???预设一个基准值 方便计算 100px 
  • 4.4 适配的时候设置基准值  320px  50px 怎么算:(640px 100px ===320px 50px)
  • 4.5 换算公式:当前rem基准值 = 预设的基准值 / 设计稿宽度 * 当前设备的宽度 
  • 4.6 怎么去改变 (js换算,影响页面加载速度,所以媒体查询推荐)动态获取当前设备宽度,然后换算单位,把设置好的基准值放进去

rem+less适配

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <title>Title</title>
    <style>
        /*假设的设备  320px 414px 640px */
        @media (min-width: 320px) {
            html{
                font-size: 50px;
            }
        }
        @media (min-width: 414px) {
            html{
                font-size: 64.6875px;
            }
        }
        @media (min-width: 640px) {
            html{
                font-size: 100px;
            }
        }
        body{
            margin: 0;
            padding: 0;
            font-size: 14px;
        }
        /*流式容器*/
        header{
            width: 100%;
            height: 1rem;
            line-height: 1rem;
            font-size: 0.32rem;
            text-align: center;
            background: green;
            color: #fff;
        }
    </style>
</head>
<body>
<header>购物车</header>
</body>
</html>

这样的方式不太好进行维护,为了更好的维护,适配更多主流设备,可以采用less+rem的适配方案。

1、定义变量  var.less

 Less可以定义数组(适配设备的集合)

@charset "UTF-8";
//变量
//rem适配方案不好维护  设备会更新  设计稿尺寸  预设基准值
//适配主流设备十几种
@adapterDeviceList:750px,720px,640px,540px,480px,424px,414px,400px,384px,375px,360px,320px;
//设计稿尺寸
@psdWidth:750px;
//预设基准值
@baseFontSize:100px;
//设备的种类 length内置函数
@len:length(@adapterDeviceList);
//主体颜色
@snColor:#fabc09;

2、混入(函数)misxins.less

  • 遍历使用的是for循环
  • less没有循环语法
  • 使用函数的迭代 会死循环
  • 根据数组的长度去停止当前循环
  • 给函数的执行附加条件   when   less的判断语法
  • 需要序号来判断  通过序号遍历 @index 1 开始
  • 遍历成功

extract(需要提取的数组,通过序号进行提取):从数组中提取


.adapterMixin(@index) when ( @index > 0){
  @media (min-width: extract(@adapterDeviceList,@index)){
    html{
      font-size: @baseFontSize / @psdWidth * extract(@adapterDeviceList,@index);
    }
  }
  .adapterMixin( @index - 1);
}

3、调用  adapter.less

.adapterMixin(@len);

4、引入这些less文件  index.less

//变量
@import "var";
//混入
@import "mixins";
//适配
@import "adapter";

这样就可以比较方便做到移动端各种主流设备的适配了。

方案是为解决特定问题或达成特定目标而制定的一系列计划或步骤。它的作用是提供一种系统性的方法,以有效地应对挑战、优化流程或实现目标。以下是方案的主要作用: 问题解决: 方案的核心目标是解决问题。通过系统性的规划和执行,方案能够分析问题的根本原因,提供可行的解决方案,并引导实施过程,确保问题得到合理解决。 目标达成: 方案通常与明确的目标相关联,它提供了一种达成这些目标的计划。无论是企业战略、项目管理还是个人发展,方案的制定都有助于明确目标并提供达成目标的路径。 资源优化: 方案在设计时考虑了可用资源,以最大化其效用。通过明智的资源分配,方案可以在有限的资源条件下实现最大的效益,提高效率并减少浪费。 风险管理: 方案通常会对潜在的风险进行评估,并制定相应的风险管理策略。这有助于减轻潜在问题的影响,提高方案的可行性和可持续性。 决策支持: 方案提供了决策者所需的信息和数据,以便做出明智的决策。这种数据驱动的方法有助于减少不确定性,提高决策的准确性。 团队协作: 复杂的问题通常需要多个人的协同努力。方案提供了一个共同的框架,帮助团队成员理解各自的职责和任务,促进协作并确保整个团队朝着共同的目标努力。 监控与评估: 方案通常包括监控和评估的机制,以确保实施的有效性。通过定期的评估,可以及时调整方案,以适应变化的环境或新的挑战。 总体而言,方案的作用在于提供一种有序、有计划的方法,以解决问题、实现目标,并在实施过程中最大化资源利用和风险管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值