uniapp view怎么按长度排列一行最多四个元素,并且换行后,每一行之间都有间隔

news/2024/10/8 9:31:24/
  • 推荐学习文档
    • golang应用级os框架,欢迎star
    • golang应用级os框架使用案例,欢迎star
    • 案例:基于golang开发的一款超有个性的旅游计划app经历
    • golang实战大纲
    • golang优秀开发常用开源库汇总
    • 想学习更多golang知识,这里有免费的golang学习笔记专栏

文章目录

    • 1.使用 Flex 布局并设置间距
    • 2.动态根据内容长度排列(可选补充)

1.使用 Flex 布局并设置间距

  • uniapp中,可以利用flex布局来实现view按要求排列。以下是一个示例代码:
  • 模板部分(template)
<template><view class="parent-view"><view v-for="(item, index) in itemList" :key="index" class="child-view">{{item}}</view></view>
</template>
  • 脚本部分(script)(这里简单定义一个示例数据数组):
export default {data() {return {itemList: ['元素1', '元素2', '元素3', '元素4', '元素5', '元素6']};},
};
.parent-view {display: flex;flex-wrap: wrap;justify-content: flex-start;gap: 10px; /* 设置元素之间的间距,这里是10px,可以根据需求调整 */
}.child-view {width: calc(25% - 10px); /* 考虑间距后每个元素的宽度,这里假设父容器宽度为100% */box-sizing: border-box;background-color: #f0f0f0; /* 可根据需求添加背景色等样式 */padding: 5px; /* 元素内部的间距,可调整 */
}

在上述代码中,parent - view类使用flex - wrap: wrap来实现换行,justify - content: flex - start使元素左对齐(如果需要其他对齐方式可以修改),gap: 10px设置了元素之间的间距。child - view类中计算了每个元素的宽度,考虑了间距因素,同时设置了一些基本的样式

2.动态根据内容长度排列(可选补充)

  • 如果想要根据内容的实际长度(例如文本长度)动态调整排列,并且满足每行最多四个元素和换行有间隔的要求,可以使用uni.createSelectorQuery()来获取每个view元素的宽度,然后进行动态布局调整。
  • 以下是一个大致的示例思路(在mounted生命周期钩子中):
mounted() {const that = this;const query = uni.createSelectorQuery().in(this);query.selectAll('.child - view').boundingClientRect(data => {let items = that.itemList;let line = [];let lines = [];let currentWidth = 0;let maxWidthPerLine = uni.getSystemInfoSync().windowWidth;let gap = 10; /* 元素之间的间距,与CSS中的设置一致 */for (let i = 0; i < data.length; i++) {let itemWidth = data[i].width;if (currentWidth+itemWidth <= maxWidthPerLine && line.length < 4) {line.push(items[i]);currentWidth += itemWidth + gap;} else {lines.push(line);line = [items[i]];currentWidth = itemWidth + gap;}}if (line.length > 0) {lines.push(line);}// 这里可以根据lines重新渲染视图,例如更新数据结构或者使用v - if/v - for组合来正确显示布局}).exec();
}

这种方式通过获取每个view元素的实际宽度,按照每行最多四个元素和间距要求进行分组,然后可以根据分组结果进一步调整布局。不过这种方法相对复杂一些,并且在内容动态变化时可能需要重新计算布局。

希望本文对你有所帮助!如果你有任何问题或建议,欢迎在评论区留言。

关注我看更多有意思的文章哦!👉👉


http://www.ppmy.cn/news/1536053.html

相关文章

Vue.js 组件开发详解

在现代前端开发中&#xff0c;Vue.js 是一款非常流行的框架&#xff0c;以其简洁的 API 和灵活的组件化体系深受开发者喜爱。在 Vue.js 中&#xff0c;组件&#xff08;Component&#xff09;是核心概念之一&#xff0c;帮助开发者构建复杂而高效的用户界面。本文将详细讲解 Vu…

Java | Leetcode Java题解之第461题汉明距离

题目&#xff1a; 题解&#xff1a; class Solution {public int hammingDistance(int x, int y) {int s x ^ y, ret 0;while (s ! 0) {s & s - 1;ret;}return ret;} }

Java之Native详解

在Java编程中&#xff0c;Native方法是一种特殊的方法&#xff0c;它允许Java代码直接调用用其他编程语言&#xff08;如C或C&#xff09;编写的代码。这种机制使得Java程序能够与底层系统资源或其他编程语言进行交互&#xff0c;实现更高效的操作或访问特定功能。本文将详细介…

vSAN01:vSAN简介、安装、磁盘组、内部架构与调用关系

目录 传统的共享存储vSAN存储OSA的系统要求vSAN安装vSAN集群vSAN skyline healthvSAN与HA磁盘组混合磁盘架构全闪磁盘架构 vSAN对象vSAN内部架构 传统的共享存储 通过隔离的存储网络使得不同的ESXi主机访问独立的存储设备。需要前期投入较高的资金单独采购存储、网络可以单独规…

嵌入式硬件设计

嵌入式硬件设计是指针对嵌入式系统&#xff08;一种专用的计算机系统&#xff0c;通常嵌入到其他设备中&#xff09;进行的硬件设计工作。嵌入式系统广泛应用于消费电子、工业控制、医疗设备、汽车电子、航空航天等领域。以下是嵌入式硬件设计的主要内容和步骤&#xff1a; 1.…

数据中心运维之困:IT性能监控的挑战与一体化智能解决方案的探索

在数字化时代&#xff0c;数据中心作为企业信息架构的基石&#xff0c;其运维管理的复杂性和重要性日益凸显。面对设备老化、资源分配不均、性能波动等重重挑战&#xff0c;运维团队往往需要投入大量精力&#xff0c;以确保数据中心的高效稳定运行。 其中&#xff0c;性能监控作…

基于Springboot办公室设备维修管理系统JAVA|VUE|SSM计算机毕业设计源代码+数据库+LW文档+开题报告+答辩稿+部署教+代码讲解

源代码数据库LW文档&#xff08;1万字以上&#xff09;开题报告答辩稿 部署教程代码讲解代码时间修改教程 一、开发工具、运行环境、开发技术 开发工具 1、操作系统&#xff1a;Window操作系统 2、开发工具&#xff1a;IntelliJ IDEA或者Eclipse 3、数据库存储&#xff1a…

Django学习笔记七:用户认证与授权

Django的用户认证与授权是Web开发中常见的需求&#xff0c;Django框架提供了一套完整的解决方案。以下是Django用户认证与授权的详细用法&#xff1a; 用户认证 用户认证是指确认用户身份的过程。Django默认使用用户名和密码进行认证&#xff0c;但也支持其他认证方式。 创建…