通过vue写一个瀑布流插件代码实例


Posted in Javascript onSeptember 07, 2019

这篇文章主要介绍了通过vue写一个瀑布流插件代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

效果如图所示:

通过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="item.url" alt="">
      </template>
</vueWaterEasy>

imgsArr:为图片数据的数组,内部包含对象 [ { src:"xxxx" } ]

srckey : 为图片路径的属性,默认为 src

maxCols: 多少列 默认为 3

gap : 每列的间距默认 10px

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
用Jquery实现可编辑表格并用AJAX提交到服务器修改数据
Dec 27 Javascript
javascript 特性检测并非浏览器检测
Jan 15 Javascript
跨浏览器开发经验总结(三)   警惕“IE依赖综合症”
May 13 Javascript
jQuery.buildFragment使用方法及思路分析
Jan 07 Javascript
使用js+jquery实现无限极联动
May 23 Javascript
捕获和分析JavaScript Error的方法
Mar 25 Javascript
浅谈JavaScript函数节流
Dec 09 Javascript
用模版生成HTML的的框架jquery.tmpl使用详解
Jan 07 Javascript
AngularJS过滤器filter用法总结
Dec 13 Javascript
Bootstrap组合上、下拉框简单实现代码
Mar 06 Javascript
基于Bootstrap表单验证功能
Nov 17 Javascript
使用vue-cli脚手架工具搭建vue-webpack项目
Jan 14 Javascript
javascript写一个ajax自动拦截并下载数据代码实例
Sep 07 #Javascript
使用layui日期控件laydate对开始和结束时间进行联动控制的方法
Sep 06 #Javascript
解决layer.open后laydate失效的问题
Sep 06 #Javascript
layui的表单验证支持ajax判断用户名是否重复的实例
Sep 06 #Javascript
layui在form表单页面通过Validform加入简单验证的方法
Sep 06 #Javascript
layui自定义验证,用ajax查询后台是否有重复数据,form.verify的例子
Sep 06 #Javascript
layer的prompt弹出框,点击回车,触发确定事件的方法
Sep 06 #Javascript
You might like
什么是短波收听SWL
2021/03/01 无线电
PHP中include()与require()的区别说明
2010/03/10 PHP
ThinkPHP查询中的魔术方法简述
2014/06/25 PHP
windows7下php开发环境搭建图文教程
2015/01/06 PHP
Thinkphp模板标签if和eq的区别和比较实例分析
2015/07/01 PHP
php基于curl重写file_get_contents函数实例
2016/11/08 PHP
php7 list()、session及其他模块的修改实例分析
2020/05/25 PHP
laravel中Redis队列监听中断的分析
2020/09/14 PHP
javascript中定义类的方法汇总
2014/12/28 Javascript
JS冒泡事件与事件捕获实例详解
2016/11/25 Javascript
前端js弹出框组件使用方法
2020/08/24 Javascript
Jquery Easyui菜单组件Menu使用详解(15)
2016/12/18 Javascript
jQuery上传插件webupload使用方法
2017/08/01 jQuery
vue父组件中获取子组件中的数据(实例讲解)
2017/09/27 Javascript
原生js实现form表单序列化的方法
2018/08/02 Javascript
JS实现中英文混合文字溢出友好截取功能
2018/08/06 Javascript
Vue自定义全局Toast和Loading的实例详解
2019/04/18 Javascript
vue项目打包后上传至GitHub并实现github-pages的预览
2019/05/06 Javascript
JavaScript Window窗口对象属性和使用方法
2020/01/19 Javascript
[51:39]DOTA2-DPC中国联赛 正赛 Magma vs LBZS BO3 第二场 2月7日
2021/03/11 DOTA
python解析xml模块封装代码
2014/02/07 Python
Python列表list数组array用法实例解析
2014/10/28 Python
浅谈python中set使用
2016/06/30 Python
python制作企业邮箱的爆破脚本
2016/10/05 Python
python脚本爬取字体文件的实现方法
2017/04/29 Python
浅谈Python实现贪心算法与活动安排问题
2017/12/19 Python
判断python对象是否可调用的三种方式及其区别详解
2019/01/31 Python
如何用Python制作微信好友个性签名词云图
2019/06/28 Python
Python标准库json模块和pickle模块使用详解
2020/03/10 Python
详解pandas中利用DataFrame对象的.loc[]、.iloc[]方法抽取数据
2020/12/13 Python
基于HTML5 Canvas 实现商场监控实例详解
2017/11/20 HTML / CSS
html5 canvas手势解锁源码分享
2020/01/07 HTML / CSS
.NET笔试题(20个问题)
2016/02/02 面试题
《美丽的田园》教学反思
2014/03/01 职场文书
破坏寝室公物检讨书
2014/11/17 职场文书
2015年工会工作总结范文
2015/07/23 职场文书