uni-app快速入门(六)--rpx尺寸单位与Flex布局

ops/2024/11/18 7:39:05/

一、uni-app尺寸单位

       uni-app支持的通用尺寸单位包括px、rpx。为支持跨平台,在搭建空驾驶建议使用Flex布局。px指屏幕像素,rpx是响应式像素,是根据屏幕宽度自适应的动态单位。假如屏幕宽度为750像素,750rpx正好为屏幕宽度。uni-app规定基准屏幕宽度为750rpx。

        设计师设计的图一般提供一个分辨率的图片,如果严格按照设计图的px进行开发,在不同宽度的手机上,界面容易变形,主要是宽度变形,因为有滚动条,在高度上一般不容易出现问题。uni-app在App端、H5端、小程序都支持rpx。页面元素在uni-app的计算公式:

    750x元素在设计稿中的宽度/设计稿基准宽度:

     假如设计稿宽度为750px,元素在设计稿宽度为100px,则元素在uni-app的宽度为750x100/750=100rpx;

     假如设计稿宽度为640px,元素在设计稿的宽度为100px,则元素在uni-app的宽度为750x100/640,约117rpx。

     当然既然知道了uni-app的基础屏幕宽度,设计稿最好直接设计成750px,这样就不用换算了。

二、Flex布局

       为支持跨平台,uni-app建议使用Flex布局(Flexible Box,弹性布局)。

       传统布局基于盒状模型,依赖display属性、position属性和float属性,如果使用Flex布局则不建议使用float属性。

      采用Flex布局的元素为Flex容易,里面的子元素为Flex项目(Flex item)。容器指定flex布局的语法:

      .box{display:flex;}

      容器内元素的flex语法:.box{display:inline-flex;}

      容器默认存在两个轴,横轴(水平主轴main axis),纵轴(垂直交叉轴 cross axis)。横轴宽度为main size,纵轴高度为cross size。横轴开始位置结束位置分别称main start、main end,纵轴开始结束位置成文cross start ,cross end,这样便于理解样式里的属性含义。

       Flex布局有6个容器属性:flex-direction 、flex-wrap、flex-flow、justify-content、align-items、align-content。

    容器里的元素有6个属性:order、flex-grow、fle-shrink、flex-basis、flex、align-self。

 【容器属性】

  1、flex-direction:决定主轴方向(项目排列方向)

        .box{

            display:flex;

            flex-direction: row;//默认值,主轴水平方向,起点为左侧;

            //flex-direction: row-reverse;//主轴水平方向,起点为右侧;

            //flex-direction: column;//主轴为垂直方向,起点为顶部;

            //flex-direction:column-reverse;//主轴为垂直方向,起点为底部;

      }

  2、flex-wrap属性:默认情况下,元素排在一条线上,又称轴线上。如果一条线无法排列所有项目,可以换行到下一条线上,代码示例:

       .box{

           display:flex;

           flex-wrap:wrap;//如果没这行,就是默认的nowrap不换行;wrap为换行,第一行在上方;

           //flex-wrap: wrap-reverse;//换行,第一行在下方;

       }

3、flex-flow:是上面flex-direction和flex-wrap加起来的简写形式,默认为row nowrap:

    .box{

        direction: flex;

        flex-flow: row nowrap;

    }

4、justify-content属性:定义项目在主轴上的对齐方式:

     .box{

         display: flex;

         justify-content: flex-start;//flex-start为默认的,左对齐;flex-end为右对齐;center为居中;

        // space-between:两端对齐,元素之间的间隔都相等;

       // space-around: 每个元素两侧的间隔相等。因此元素之间的间隔比元素与边框的间隔大一倍。

5、align-items:定义项目在交叉轴(纵轴)的对齐方式

       .box{

           display:flex;

           align-items: flex-start;//flex-start:纵轴起点对齐、fllex-end纵轴终点对齐、content:纵轴中点对齐。baseline:元素第一行文字的基线对齐;stretch(默认值):如果元素未设置高度或设置为auto,则将占满整个容器高度。

        }

}

6、align-content:定义多条轴线对齐方式,如果元素只有一条轴线,则此属性不起作用。

    .box{

        display:flex;

       align-content: flex-start;//与交叉轴起点对齐。flex-end:与交叉轴终点对齐。center:与交叉轴中点对齐。space-between:与交叉轴两端对齐,轴线之间间隔相等;space-around:每条轴线两侧的间隔相等。因为,轴线之间的间隔比轴线与边框的间隔大一倍。stretch(默认):轴线占满整个交叉轴。

    }

【元素属性】

1、order属性:定义元素的排列顺序,order越小越靠前

.item{

    order: 1;

}

2、flex-grow:定义元素的放大比例,默认为0,即使有剩余空间,也不放大:

   .item{ flex-grow: 0;}

    如果都是1,则等分空间;如果其中一个是2,其他为1,则这个2的元素比其他元素占用空间大倍。

3、flex-shrink:定义元素的缩小比例,默认为1,即如果空间不足,则该元素将缩小。

        .item{ flex-shrink: 1;} 

        如果所有元素flex-shrink都是1,则等比例缩小;如果设置为0的则不缩小。负值对该属性无效。

4、flex-basis:定义在分配多余空间之前该元素占的空间。浏览器根据该属性计算主轴是否有多余空间,默认为auto,即元素本来大小。

         .item{ flex-basis: auto;} //flex-basis可设置为与width或height属性一样的值,则元素将占据固定空间值;

5、flex:是flex-grow、flex-shrink、flex-basis的简写,就是说三周属性可设置到一起,默认值是0 1 auto 其中后两个属性为可选项:

.item{flex : 0 1 auto}

6、align-self:允许单个元素与其他元素不一样的对齐方式,可覆盖align-items属性,默认为auto,表示集成父元素的align-items属性,如果没有父元素,则等同于stretch:

.item{align-self:auto;}

该属性可以取6个值,除了auto外,其他都与align-items属性值完全一致。

        

       


http://www.ppmy.cn/ops/134648.html

相关文章

2024年09月CCF-GESP编程能力等级认证Python编程四级真题解析

本文收录于专栏《Python等级认证CCF-GESP真题解析》,专栏总目录:点这里,订阅后可阅读专栏内所有文章。 一、单选题(每题 2 分,共 30 分) 第 1 题 据有关资料,山东大学于1972年研制成功DJL-1计算机,并于1973年投入运行,其综合性能居当时全国第三位。DJL-1计算机运算控…

Spark RDD中常用聚合算子源码层面的对比分析

在 Spark RDD 中,groupByKey、reduceByKey、foldByKey 和 aggregateByKey 是常用的聚合算子,适用于按键进行数据分组和聚合。它们的实现方式各不相同,涉及底层调用的函数也有区别。以下是对这些算子在源码层面的分析,以及每个算子…

使用 Grafana api 查询 Datasource 数据

一、使用grafana 的api 接口 官方API 二、生成Api key 点击 Administration -》Users and accss -》Service accounts 进入页面 点击Add service account 创建 service account 点击Add service account token 点击 Generate token , 就可以生成 api key 了 三、进入grafana…

设计模式-行为型-常用-2:职责链模式、状态模式、迭代器模式

目录 职责链模式 概念 代码实现 使用场景 扩展-Servlet Filter 扩展-Spring Interceptor 状态模式 什么是有限状态机? 状态机实现方式一:分支逻辑法 状态机实现方式二:查表法 状态机实现方式三:状态模式 迭代器模式 定…

函数式组件和类组件的区别

函数式组件和类组件的区别 函数式组件和类组件的区别1. 语法2. 状态管理3. 生命周期管理4. this5. 创建组件6. 继承7. 性能优化 为什么推荐使用函数式组件函数式组件的优势 函数式组件和类组件的区别 1. 语法 函数式组件:基于函数式编程思想,使用 函数…

c语言学习21数组

1.1数组介绍 概念:数组就是 相同数据类型 的一组数据的集合 数组中每个数据 元素 用一个名字来命名这个集合 数组名 用编号区分 下表(从0开始自动标号) 当处理大量…

Unreal engine5实现类似鬼泣5维吉尔二段跳

系列文章目录 文章目录 系列文章目录前言一、实现思路二、具体使用蓝图状态机蓝图接口三、中间遇到的问题 前言 先看下使用Unreal engine5实现二段跳的效果 一、实现思路 在Unreal Engine 5 (UE5) 中使用蓝图系统实现类似于《鬼泣5》中维吉尔的二段跳效果,可以通…

IDEA报包不存在,但实际存在

IDEA版本2024.2.1 现象 在IDEA里启动运行项目,报某个类有问题,引入的包不存在。 点击这个引入的包,可以看到它在左侧外部库里存在。 试过的无效方法 双击ctrl,在弹出框中mvn idea:idea在文件里,清空缓存并重启在右…