分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 软件开发

vue-waterfall2 基于Vue.js 瀑布流组件

发布时间:2023-09-06 02:26责任编辑:顾先生关键词:js瀑布流组件

vue-waterfall2

  • 1.宽度自适应,数据绑定特效(适用于上拉加载更多)
  • 2.自定义程度高
  • 3.使用极为简便,适用于PC/移动端
  • 4.提供resize(强制刷新布局-适用于下拉刷新)/mix(扰乱布局) API,一般情况下不需要用到
  • 5.后期将持续更新,提供animation(过渡动画)

Demo

DEMO
GITHUB

Installation

npm install --save vue-waterfall2

Usage

注意:
?1.itemWidth需要与gutterWidth一起使用才会生效,否则会进行自适应宽度(使用rem布局时,需先计算出高度再传值)
?2.使用了waterfall的组件不允许使用scoped,否则样式会有问题

main.js
import waterfall from ‘vue-waterfall2‘Vue.use(waterfall)
app.vue
<template> ?<div class="container-water-fall"> ???<div><button ?@click="loadmore">loadmore</button> <button @click="mix">mix</button> <button @click="switchCol(‘5‘)">5列</button> <button @click="switchCol(‘8‘)">8列</button> <button @click="switchCol(‘10‘)">10列</button> </div> ???<waterfall :col=‘col‘ ?:gutterWidth="gutterWidth" ?:data="data" @finish="finish" ??> ?????<template > ???????<div class="cell-item" v-for="(item,index) in data"> ?????????<img :src="item.img" ?/> ?????????<div class="item-body"> ?????????????<div class="item-desc">{{item.title}}</div> ?????????????<div class="item-footer"> ?????????????????<div class="avatar" :style="{backgroundImage : `url(${item.avatar})` }"></div> ?????????????????<div class="name">{{item.user}}</div> ?????????????????<div class="like" :class="item.liked?‘active‘:‘‘" > ?????????????????????<i ></i> ?????????????????????<div class="like-total">{{item.liked}}</div> ???????????????????</div> ?????????????</div> ?????????</div> ???????</div> ?????</template> ???</waterfall> ?????</div></template>/* ?注意: ?1.itemWidth需要与gutterWidth一起使用才会生效,否则会进行自适应宽度(使用rem布局时,需先计算出高度再传值) ?2.使用了waterfall的组件不允许使用scoped,否则样式会有问题*/import Vue from ‘vue‘ ???export default{ ???????data(){ ?????????return{ ???????????data:[], ???????????col:‘5‘, ?????????} ???????}, ???????computed:{ ?????????itemWidth(){ ?????????????return (138*0.5*(document.documentElement.clientWidth/375)).toString() ??#rem布局 计算宽度 ?????????}, ?????????gutterWidth(){ ???????????return (9*0.5*(document.documentElement.clientWidth/375)).toString() ???#rem布局 计算x轴方向margin(y轴方向的margin自定义在css中即可) ?????????} ???????}, ???????methods:{ ?????????mix(){ ???????????this.$waterfall.mix() ?????????}, ?????????switchCol(col){ ???????????this.col = col ???????????console.log(this.col) ?????????}, ?????????loadmore(index){ ???????????this.data = this.data.concat(this.data) ?????????}, ?????????finish(){ ???????????console.log(‘finish‘) ???????} ???},

<waterfall> Props

NameDefaultTypeDesc
col‘2‘Stringthe number of column
widthnullStringthe value of width
gutterWidth10Stringthe value of margin
data[]Arraydata

$waterfall API

this.$waterfall.resize() ??this.$waterfall.mix() ??

原文地址:https://segmentfault.com/a/1190000017042878

vue-waterfall2 基于Vue.js 瀑布流组件

原文地址:https://www.cnblogs.com/lovellll/p/10124409.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved