• vue-waterfall2 基于Vue.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

    Name Default Type Desc
    col '2' String the number of column
    width null String the value of width
    gutterWidth 10 String the value of margin
    data [] Array data

    $waterfall API

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

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

  • 相关阅读:
    网页a标签:导航制作 怎么让鼠标经过A标签的时候显示块状背景?
    从头开始,慢慢来,今天工作日志
    想看所有的美国系列电影
    百分比宽度并排元素浮动之后,设置margin,padding换行的问题
    TP5.1 首页路由
    关于Layui 响应式移动端轮播图的问题
    BootStrap 栅格化换行问题
    VS code 格式化插件, 仅需一步, 无须配置
    PHPStorm 批量选择,多光标同时编辑相同的内容
    使用Cmder 安装 Composer 出现 "attempt to call a nil value"
  • 原文地址:https://www.cnblogs.com/lovellll/p/10124409.html
Copyright © 2020-2023  润新知