小程序瀑布流实现

news/2024/5/6 6:15:12/文章来源:https://blog.csdn.net/example440982/article/details/128111727

什么是瀑布流布局

瀑布流布局,一般等宽,不等高的列表排列

原理是找出高度之和最小的那一列,在高度最小列继续添加元素

可以通过 absolute 定位实现,动态计算每一项的 topleft

在这里插入图片描述

封装瀑布流方法

function getAllRect(context, selector) {return new Promise(function (resolve) {wx.createSelectorQuery().in(context).selectAll(selector).boundingClientRect().exec(function (rect) {if (rect === void 0) {rect = []}return resolve(rect[0])})})
}/*** 瀑布流* @param {*} context 页面或组件this对象* @param {string} selector 选择器* @param {Object} options* @param {number=375} options.width 屏幕宽度* @param {number=2} options.column 列数* @param {number|string} options.gap 每列直接的间隙* @param {number=0} options.padding 整个列表左右的padding* @param {number=0}* @returns {Array} 计算每项的top、left、height的数组*/
async function waterFall(context, selector, options = {}) {let items = await getAllRect(context, selector)if (items.length <= 0) return []let { gap = 15, column = 2, padding = 0, width = 375, firstColumnToTop = 0 } = options// 1- 确定列数  = 页面的宽度 / 图片的宽度,单例的宽度let itemWidth = items[0].width// 定义每一列之间的间隙 pxif (gap === 'auto') {gap = (width - itemWidth * column) / (column - 1)}let _columnHeightArr = [] // 保存每列高度let result = []for (let i = 0, len = items.length; i < len; i++) {if (i < column) {// 2- 确定第一行let top = firstColumnToToplet left = (itemWidth + gap) * i + padding// 瀑布流列表左右paddingif (i === 0 || i === len - 1) {left = padding}_columnHeightArr.push(items[i].height - top)result.push({top,left,height: items[i].height,})} else {// 其他行// 3- 找到数组中最小高度  和 它的索引let minHeight = Math.min(..._columnHeightArr)let minIndex = _columnHeightArr.findIndex((item) => item === minHeight)// 4- 设置下一行的第一个盒子位置// top值就是最小列的高度 + gapresult.push({top: _columnHeightArr[minIndex] + gap,left: result[minIndex].left,height: items[i].height,})// 5- 修改最小列的高度// 最小列的高度 = 当前自己的高度 + 拼接过来的高度 + 间隙的高度_columnHeightArr[minIndex] = _columnHeightArr[minIndex] + items[i].height}}return result
}

使用

vim demo.wxml

    <!--需要子元素撑大父元素高度的情况,才需要设置height--><view class="goods_list flex flex-wrap relative" style="width:100%;height:{{height}}"><block wx:for="{{list}}" wx:key="index"><view class="goods_item" style="position:absolute;top:{{ item.top }}px;left:{{ item.left }}px"bindtap="handleItem" data-item="{{item}}"><view class="goods_img"><goodsImage detail="{{ {imgUrl:item.goodsIcon} }}" isAllowCash="{{true}}"></goodsImage></view><view class="goods_mes"><view class="goods_name g-t-over2">{{item.goodsName}}</view><view class="goods_price">{{item.price}}</view></view></view></block></view>

vim demo.js

// 需要在节点加载到页面后调用
onReady() {const { screenWidth, list } = this.datawaterFall(this, '.goods_item', { width: screenWidth, gap: 'auto' }).then((arr) => {if (!arr.length) returnlet lastNode = arr[arr.length - 1]let height = lastNode.top + lastNode.height + 'px'this.setData({list: list.map((item, index) => ({ ...item, ...arr[index] })),height,})})
}

效果

在这里插入图片描述

小结

既然都封装成函数了,为什么不封装成组件调用呢?

组件调用可以参考这个小程序的瀑布流组件me-waterfall

我看了这个组件的源码,用到组件间关系来实现瀑布流结构,整个瀑布流组件内部也需要父子组件关系,父组件监听子组件插入元素,获取元素的动态高度,往高度最小列添加新元素。

但是我引入使用,在组件内使用me-waterfall 组件,组件间关系方法 linked 不生效,官方论坛也找不到原因,便弃用。
类似这样的结构:

<!--page.wxml-->
<view><goodsList />
</view<!--goodsList.wxml-->
<view><me-waterfall><me-waterfall-item wx:for="{{list}}" wx:key="index"><image src="{{item.imgUrl}}" style="width:100%;height:{{item.height}}px" /></me-waterfall-item></me-waterfall>
</view

于是,自己封装一个方法使用。便有了此文。

封装成方法也有优点,不需要引入组件,简单引入一下方法调用即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_227994.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[附源码]Python计算机毕业设计Django的疫苗接种管理系统

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…

c#、wpf开发中页面在win10下被缩放125%引起页面错乱的解决办法。

正常情况下,我们开发的页面页面应该是100%缩放的,这样程序在win7和win10下保持一致,但是win10里面会根据显示器的情况自动调整“缩放与布局”,这使得桌面程序有时候会发生页面错乱,怎么调整就是个问题。 如图:在“缩放与布局”100%显示如下: 而在 “缩放与布局”125%显…

基于AD Event日志检测LSASS凭证窃取攻击

01、简介 简单介绍一下&#xff0c;LSASS(本地安全机构子系统服务)在本地或域中登录Windows时&#xff0c;用户生成的各种凭证将会存储在LSASS进程的内存中&#xff0c;以便用户不必每次访问系统时重新登录。 攻击者在获得起始攻击点后&#xff0c;需要获取目标主机上的相关凭证…

小程序中的confirm-type设置键盘的确认按钮

详情&#xff1a; confirm-type是很多小程序组件中的一种设置&#xff0c;用于改变输入键盘右下角的确认按钮。比如说&#xff0c;正常情况下&#xff0c;键盘上的默认提示可能是完成&#xff0c;但是你可以通过confirm-type将其设置为发送&#xff0c;搜索等&#xff0c;在特…

搬砖日记:关于sync用不了的问题

自己封装了个输入框的组件&#xff0c;想要实现的输入框的值的修改可以实时修改到父组件的值 印象中看到过人家用.sync修饰符去实现这个功能&#xff0c;大抵是 //父组件 <searchInput :value.sync"value"></searchInput> //子组件 <input v-model&qu…

Redeis缓存查询基于元注解与AOP结合使用——不过时的优雅

Redeis缓存查询基于元注解与AOP结合使用 根据优化需要&#xff0c;数据查询的时候无法避免的使用Redis基于缓存查询&#xff0c;进而减少对于数据库的查询压力&#xff0c;对于过多的方法基于缓存存储&#xff0c;为提高代码的复用性&#xff0c;采用一种不过时的写法。 整体的…

一文详解,数据仓库、数据库、数据中台、数据湖的区别

数据时代&#xff0c;各行业的企业都已经开始通过数据库来沉淀数据&#xff0c;但是真的论起数据库、数据仓库、数据中台&#xff0c;还是新出现的数据湖&#xff0c;它们的概念和区别&#xff0c;可能知道的人就比较少了&#xff0c;今天我们详细来比较了解一下。 数据仓库是…

你的数据库到底应该如何存储密码?

最近接手公司一个之前的服务&#xff0c;竟然发现用户密码是明文存储在数据库中&#xff01; 说实话还是有点吃惊的&#xff0c;这可不兴学 CSDN 呀&#xff08;手动狗头&#xff09;&#xff0c;至少也得搞个 MD5 存一存吧。 不过 MD5 其实也没啥用&#xff0c;今天我们就来…

JVM之运行时数据区 PC、虚拟机栈、本地方法栈

JVM之运行时数据区 PC、虚拟机栈、本地方法栈PC寄存器线程回顾寄存器实践面试使用PC寄存器存储字节码指令地址有什么用&#xff1f;为什么使用PC寄存器记录当前线程的执行地址PC寄存器为什么会被设定为线程私有虚拟机栈虚拟机栈出现背景简介栈可能出现的异常栈中存储着什么运行…

电商新趋势:Starday拿下黑色星期五的制胜法宝是物流速度

国内电商“双十一”购物狂欢季活动已经闭幕&#xff0c;“双十二”又将袭来&#xff0c;但更多人却将眼光放在蓬勃发展的跨境电商行业中。当下跨境电商卖家们正在各大跨境电商服务平台的带领下全力备战&#xff0c;在“黑色星期五”期间推出各类大促活动&#xff0c;奋力冲刺20…

Unknown custom element: <el-image>无法使用该组件,升级element-ui版本后项目报错

需求背景&#xff1a; 项目中需要使用图片点击放大&#xff0c;想要使用<el-image>组件&#xff0c;引入后报了下面的错&#xff0c;需要升级element版本&#xff0c;element-ui版本过低&#xff0c;没有该组件。 过程&#xff1a; cnpm i element-ui2.14.1 --save-dev…

clickhouse远程访问Oracle 11g数据库(clickhouse-jdbc-bridge)

1、简介 clickhouse-jdbc-bridge&#xff1a;是clickhouse提供的一个jdbc组件&#xff0c;用于通过JDBC的方式远程访问其他数据库表。 2、安装 &#xff08;1&#xff09;下载源文件并打包获取clickhouse-jdbc-bridge-2.0.7-shaded.jar 在官网&#xff1a;https://github.c…

tictoc例子理解10-13

tictoc10-13tictoc 10 几个模块连接&#xff0c;发送消息直到模块3收到消息tictoc 11 新增信道定义tictoc 12 双向连接信息简化定义tictoc 10 几个模块连接&#xff0c;发送消息直到模块3收到消息 让我们用几个(n)’ tic’模块让它更有趣&#xff0c;并将每个模块连接到其他模…

ANR 触发、监控、分析 一网打尽

平时看博客或者学知识&#xff0c;学到的东西比较零散&#xff0c;没有独立的知识模块概念&#xff0c;而且学了之后很容易忘。于是我建立了一个自己的笔记仓库 (一个我长期维护的笔记仓库&#xff0c;感兴趣的可以点个star~你的star是我写作的巨大大大大的动力)&#xff0c;将…

大客车玻璃擦净器设计

目 录 摘 要 I ABSTRACT II 1 绪论 1 1.1选题背景及意义 1 1.2发展现状 2 1.3发展趋势 3 1.4研究主要内容 4 2 大客车玻璃擦净器总体方案设计 5 2.1 大客车玻璃擦净器设计思想 5 2.2功能分析 5 2.3工作原理分析 6 2.4功能分解 6 2.4.2传动系统 6 2.4.3真空吸盘 7 2.4.4 清洁刷 …

欢聚季报图解:营收5.87亿美元同比降10% 净利提升

雷递网 雷建平 11月29日欢聚集团(NASDAQ: YY)今日发布2022年第三季度财报。财报显示&#xff0c;欢聚集团2022年第三季度营收为5.867亿美元&#xff0c;较上年同期下降10%。欢聚集团2022年第三季度Bigo Live的平均移动MAU为3540万&#xff0c;较上年同期的3100万增长14.2%&…

转铁蛋白修饰的去氢骆驼蓬碱磁纳米脂质体TF-HM-MPS

转铁蛋白又名运铁蛋白&#xff08;Transferrin&#xff0c;TRF、Tf&#xff09;&#xff0c;负责运载由消化管吸收的铁和由红细胞降解释放的铁。以三价铁复合物&#xff08;Tf-Fe3&#xff09;的形式进入骨髓中&#xff0c;供成熟红细胞的生成。转铁蛋白主要存在于血浆中&#…

冒烟测试的7个好处,你是否经常用到它?

以下为作者观点&#xff1a; 冒烟测试(smoke testing)是在开发的早期阶段评估基本的软件组件&#xff0c;以检查它们是否 “着火”&#xff08;有问题&#xff09;&#xff0c;本文旨在介绍冒烟测试及其在程序开发过程中的作用。 什么是冒烟测试&#xff1f; 冒烟测试是在开…

企业日常公关如何抵御负面信息的入侵?

如今&#xff0c;互联网时代信息传播速度极快&#xff0c;这使得宣传工作效率倍增&#xff0c;也给企业舆情管理带来一定的挑战。舆情优化搞得好&#xff0c;企业宣传工作事半功倍&#xff0c;网络舆论走向负面的话&#xff0c;则对宣传工作非常不利&#xff0c;会导致推广效果…

狂神说Go语言学习笔记(一)

一、Go语言的发展史 二、Go语言能做什么 三、Go语言环境安装 下载地址 国外网站太慢&#xff0c;我们使用中文网进行下载&#xff01; Go下载 - Go语言中文网 - Golang中文社区 (studygolang.com) 安装 无脑下一步就完了 &#xff0c;注意下这里创建自己设置一个Go语言的环…