这篇文章主要介绍了通过vue写一个瀑布流插件代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
效果如图所示:
采用了预先加载图片,再计算高度的办法。。网络差的情况下,可能有点卡
新建 vue-water-easy.vue 组件文件
<template> <div class="vue-water-easy" ref="waterWrap"> <div v-for="(items,clos) in list" :key="clos" :style="waterStyle" class="colsW"> <ul> <li v-for="(item,index) in items" :key="index" :style="{marginBottom:gap+'px'}"> <slot :item="item" :index="index" :clos="clos"></slot> </li> </ul> </div> </div> </template> <script> export default { props:{ maxCols:{ type:Number, default:3, validator(value){ return value > 1; } }, srcKey:{ type:String, default:"src" }, gap:{ type:Number, default:10, validator(value){ return value > 0; } }, imgsArr:{ type:Array, required:true } }, computed:{ waterStyle(){ if(this.gap <= 0){ this.gap = 10; } return { margin:`0 ${this.gap/2}px` } } }, watch:{ imgsArr(val){ this.$nextTick(()=>{ this.list = this.initData(); this.start(0); }) } }, data(){ let list = this.initData(); return { list:list } }, mounted(){ this.start(0); }, methods:{ initData(){ let list = new Array(this.maxCols); for(let i = 0; i < this.maxCols ; i++){ list[i] = []; } return list; }, start(i){ const me = this; let imgsArr = me.imgsArr; if(i >= imgsArr.length && this.$refs.waterWrap){ return ; } me.loadImg(imgsArr[i],i).catch(()=>{ }).finally(()=>{ me.start(++i); }); // for(let i = 0; i < imgsArr.length; i++ ){ // let item = imgsArr[i]; // me.loadImg(item,i); // } }, loadImg(item){ const me = this; let srcKey = me.srcKey; return new Promise(function(resolve,reject){ if(item && item[srcKey]){ let src = item[srcKey]; let img = new Image(); img.src = src; img.crossOrigin = "anonymous"; img.onload = function(){ var index = me.getMinHeight(); me.list[index].push(item); me.$nextTick(()=>{ resolve(img) }); } img.onerror = function(e){ reject(e); } }else{ reject('数据错误'); } }) }, getMinHeight(){ let index = 0; try{ if(!this.$refs.waterWrap){ return index; } let childs = this.$refs.waterWrap.children || []; let minx = childs[0].children[0].offsetHeight; for(let i = 1; i < childs.length; i++){ let element = childs[i]; let h = element.children[0].offsetHeight; if(h < minx){ minx = h ; index = i; } } }catch(e){ console.warn(e); return index; } return index; } } } </script> <style lang="scss" scoped> .vue-water-easy{ width: 100%; display: flex; justify-content: space-between; div.colsW{ flex: 1; box-sizing: border-box; position: relative; &:last-child{ margin-right: 0 !important; } &:first-child{ margin-left: 0 !important; } ul{ list-style: none; width: 100%; li{ width: 100%; } } } } </style>
使用
<vueWaterEasy :imgsArr="imgsArr" srcKey="url"> <template v-slot="{item}"> <img :src="/UploadFiles/2021-04-02/item.url">imgsArr:为图片数据的数组,内部包含对象 [ { src:"xxxx" } ]
srckey : 为图片路径的属性,默认为 src
maxCols: 多少列 默认为 3
gap : 每列的间距默认 10px
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年11月26日
2024年11月26日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]