小红书瀑布流布局实现

技术栈:vue3

实现背景:最近项目不忙,想拿掘金文章联系一些小demo,分享一个小菜鸡的踩坑历程!!

借鉴文章:借鉴是雅称,俗称叫照葫芦画瓢加上一些自己的理解!!

借鉴地址:https://juejin.cn/post/7322655035699396660

实现过程:

思想:外层盒子使用绝对定位,里层每单个盒子使用相对定位,第一行正常排列,第二行排在第二行高度最小的下方

资源:小红书network在网络模块搜索:homefeed接口
一:将接口数据分别定义在public文件里面data.json,使用fetch请求public文件

  1. 我们看看如果实现这个方式需要什么参数:1.原始数据:接口请求过来的数据carList:[]
  2. 2.我们每次都需要对比上一行的高度所以需要把上一行的高度全部存起来,多少个???暂定为可传参数column,将上一行高度放在一个数组里面columnHeight: new Array(props.column).fill(0)
  3. 我们是使用平移的css实现方式,需要知道每个盒子的宽高以及平移的x,y。。。。cardPos: []
  4. 我们需要给盒子定宽度itemWidth: 0,每个盒子的宽度是一定的,
  5. 再就是列表查询参数,page:1,isFinish: false,(是否是最后一页)
    二:接下来看看css,html的怎么实现

tip:记得加入box-sizing:border-box!!!

三 :生命周期初始化

computedCardPos函数

获取最小高度以及最小高度的坐标是我们经常需要可以放到computed里面计算

父组件里面我们定义插槽出口

const colorArr = ["#409eff", "#67c23a", "#e6a23c", "#f56c6c", "#909399"];

从父组件传来的column我们还没有解决!!!!

父组件:

子组件:

相关推荐
喜欢吃鱿鱼12 分钟前
DES加解密(附带解决转义问题)-VUE
开发语言·前端·javascript
腹黑天蝎座14 分钟前
前端性能优化实战指南:从原理到落地的全方位解决方案
前端·性能优化·监控
忆往wu前19 分钟前
一文通透 Vue动态组件体系:插槽|数据监听|组件通信|动态切换|缓存—闭环
前端·面试
奇奇怪怪的问题20 分钟前
问题总结:关于封装axios问题,导致外部使用接口报错,无法进入error回调
前端·axios
Jenlybein20 分钟前
速学 VS Code 插件开发入门,客制化你的开发体验
前端·javascript·visual studio code
qq_437100661 小时前
SSE 流式响应(Server-Sent Events)
前端·sse
十六年开源服务商1 小时前
游戏与设计驱动WordPress建站2026
java·前端·游戏
ZC跨境爬虫1 小时前
UI前端美化技能提升日志day7:(原生苹方字体全局适配+合规页脚完整像素级落地)
前端·javascript·ui·html·交互
好运的阿财1 小时前
OpenClaw工具拆解之tts+web_search
前端·javascript·python·ai·ai编程·openclaw·openclaw工具
whinc2 小时前
Node.js技术周刊 2026年第17周
前端·javascript