Vue<瀑布流加载效果>

效果图:
waterfallFlow.gif

😀身为程序员不仅要'造轮子'玩,更要学会找轮子玩。今天有点闲,就想着学学怎么实现瀑布流效果,找了找发现用原生js实现起来也不算太困难,但是网上的写法却有很多种,而且有的并不符合在项目中的实际应用,想了解实现原理的可以参考这篇文章https://blog.csdn.net/zhaoxiang66/article/details/82876492

因此找到了 vue-waterfall 这个好东西,人家封装好的组件,可以拿来用哦!而且实用性也比较强,gitHub也是有1.7k的星星✨,感觉还是很可靠的。
gitHub地址和相关参数配置地址:https://github.com/MopTym/vue-waterfall

此篇文章主要讲的是如何利用 element-ui(无限滚动) + vue-waterfall 实现在项目中,滑到底部加载更多的具体实现~~~
····
不太熟悉element-ui(无限滚动)
可以参考官方文档https://element.eleme.cn/#/zh-CN/component/infiniteScroll
也可以参考这篇文章https://www.jianshu.com/p/4ce227a72cd0
····
npm install --s element-ui vue-waterfall

代码如下:
<template>
  <div
    class="main"
    ref="main"
    v-infinite-scroll="load"
    infinite-scroll-disabled="disabled"
    infinite-scroll-delay="500"
  >
    <!-- infinite-scroll-delay  element-ui 默认是200ms ,interval  vue-waterfall 的回流动作之间的最小时间间隔也是 200ms,相等的话会有冲突 -->
    <waterfall :line-gap="w/waterLine">
      <waterfall-slot
        v-for="(item, index) in list"
        :width="w/waterLine"
        :height="randomHeightList[index].height"
        :order="index"
        :key="item.id"
      >
        <div class="box" :style="`animation-delay: ${randomHeightList[index].delay}s`">
          <div class="content" :style="`background:${randomHeightList[index].bck}`">
            <div class="img" v-if="item.imgUrl">IMG</div>
            <div class="msg">{{index+1}}</div>
          </div>
        </div>
      </waterfall-slot>
    </waterfall>
    <section class="noMore">
      <p v-if="loading" style="margin-top:10px;" class="loading">
        <span></span>
      </p>
      <p v-if="noMore" style="margin:10px 0;font-size:12px;color:#ccc">没有更多了</p>
    </section>
  </div>
</template>

<script>
import { waterfall, WaterfallSlot } from "vue-waterfall";
export default {
  components: {
    waterfall,
    WaterfallSlot
  },
  data() {
    return {
      w: 0, //窗口宽度
      waterLine: 3, //几列瀑布流  此处是3列
      randomMinHeight: 120, //随机最小高度
      randomMaxHeight: 300, //随机最大高度
      totalPages: 0, //后端返回的总条数
      count: 0, //起始页码
      list: [], //后端返回的数据列表
      scrollbarWidth: 0, //滚动条宽度
      loading: false,
      randomHeightList: [] //储存随机高度的列表,避免再次请求数据,list改变导致数据重新渲染
    };
  },
  computed: {
    noMore() {
      //当起始页数大于总页数时停止加载
      return this.count >= this.totalPages - 1;
    },
    disabled() {
      return this.loading || this.noMore;
    }
  },
  created() {
    this.getMessage();
  },
  mounted() {
    this.judgeScroll();
  },
  methods: {
    // m~n之间的随机整数
    random(m, n) {
      return Math.floor(Math.random() * (n - m + 1) + m);
    },
    //解决PC端有滚动条时造成的窗口变化,导致无法铺满整个屏幕
    judgeScroll() {
      let odiv = this.$refs["main"];
      this.scrollbarWidth = odiv.offsetWidth - odiv.clientWidth;
      this.w = window.innerWidth - this.scrollbarWidth;
    },
    //滑到底部时进行加载
    load() {
      this.loading = true;
      setTimeout(() => {
        this.count += 1; //页数+1
        this.getMessage(); //调用接口,此时页数+1,查询下一页数据
      }, 2000);
    },
    //获取后端返回的数据信息
    getMessage() {
      let params = {
        pageNumber: this.count, //查询页数
        pageSize: 20 //每页查询条数
      };
      this.$axios
        .post(
          "https://xxxxxx后端的数据分页接口xxxxxxxx",
          params,
        )
        .then(res => {
          console.log(res);

          //每次请求数据都会把相对应的随机瀑布高度给存到 randomHeightList ,方便list变化时,直接取相对应的randomHeightList 高度
          let heightList = [];
          for (let i = 0; i < res.data.body.content.length; i++) {
            let obj = {
              height: this.random(this.randomMinHeight, this.randomMaxHeight),
              bck: `hsl(210, 100%, ${this.random(63, 85)}%)`,
              delay: i / 10
            };
            heightList.push(obj);
          }
          this.randomHeightList = this.randomHeightList.concat(heightList);

          //因为每次后端返回的都是数组,所以这边把数组拼接到一起
          this.list = this.list.concat(res.data.body.content);
          this.totalPages = res.data.body.totalPages;
          this.loading = false;
        })
        .catch(err => {
          console.log(err);
        });
    }
  }
};
</script>

<style lang="scss" scoped>
.main {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  overflow-y: scroll;
}
.noMore {
  width: 100%;
}
.loading span {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid #409eff;
  border-left: 2px solid transparent;
  animation: zhuan 0.5s linear infinite;
  border-radius: 50%;
}
@keyframes zhuan {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}
.box {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1px;
  box-sizing: border-box;
  animation: BOX 0.5s ease both 1;

  .content {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    cursor: pointer;
    &:hover .msg {
      transform: scale(1.5);
    }
    .img {
      width: 100%;
      height: 100%;
      color: white;
      font-weight: 400;
      position: absolute;
      background: #409eff;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 2rem;
      z-index: 99;
      &:hover {
        opacity: 0;
      }
    }
    .msg {
      transition: 0.5s;
      color: white;
      font-weight: 200;
      font-size: 2rem;
    }
  }
}
@keyframes BOX {
  0% {
    opacity: 0;
    transform: scale(0.8);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
</style>

点个赞呗 👍 ~~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,417评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,921评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,850评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,945评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,069评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,188评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,239评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,994评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,409评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,735评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,898评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,578评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,205评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,916评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,156评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,722评论 2 363
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,781评论 2 351

推荐阅读更多精彩内容

  • 简说Vue (组件库) https://github.com/ElemeFE/element" 饿了么出品的VUE...
    Estrus丶阅读 1,604评论 0 1
  • 基于Vue的一些资料 内容 UI组件 开发框架 实用库 服务端 辅助工具 应用实例 Demo示例 element★...
    尝了又尝阅读 1,144评论 0 1
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    小姜先森o0O阅读 9,430评论 0 72
  • 点评内容: 1、我喜欢/不喜欢你的这篇文章,为什么? 很喜欢这篇文章,文章有种内在的力量,那种自我成长的心劲很足。...
    七年一遇阅读 90评论 0 2
  • 女儿画作20181013 ✨每日金句: 如何过一天,就是如何过一生。 每日小确幸: 利用等待的时间,...
    智享_GENE阅读 213评论 0 1