小程序实现瀑布流和上拉加载

更新日期: 2020-02-23阅读: 2.6k标签: 瀑布流

瀑布流又称瀑布流式布局,是比较流行的一种网站页面布局方式。视觉表现为参差不齐的多栏布局,即多行等宽元素排列,后面的元素依次添加到其后,等宽不等高。这里只是实现了简单的效果,话不多说上效果图。



代码
wxml基本布局

<view class="content">
    <view class="item-view item-left">
        <block wx:for="{{imglist}}" wx:key="*this">
            <template is="item" data="{{...item}}" wx:if="{{index%2==0}}"></template>
        </block>
    </view>
    <view class="item-view">
        <block wx:for="{{imglist}}" wx:key="*this">
            <template is="item" data="{{...item}}" wx:if="{{index%2==1}}"></template>
        </block>
    </view>
</view>
<template name="item">
    <view class='item'>
        <image class="image" src="{{src}}" mode="widthFix"></image>
        <view class="box-shadow">
            <view class="title">{{desc}}</view>
            <view class="count">{{count}} 人做过</view>
        </view>
    </view>
</template>

wxss样式代码

.content {
    position:  relative;
    border-radius:  10rpx  10rpx  0  0;
    padding-top:  20rpx;
}
.content::after {
    content:  '';
    clear:  both;
    display:  block;
}
.item {
    width:  100%;
    margin:  0  auto;
    background: #fff;
    box-sizing:  border-box;
    position:  relative;
    padding:  24rpx;
    padding-top:  10rpx;

}
.item-view {
    float:  left;
    width:50%;
}
.item .image {
    width:  100%;
    border-radius:  10rpx  10rpx  0  0;
}
.box-shadow {
    padding:  6rpx  10rpx  18rpx  10rpx;
    box-sizing:  border-box;
    box-shadow:  0  2rpx  2rpx  rgba(88,  88,  88,  0.233);
    border-radius:  0  0  10rpx  10rpx;
}
.item-left .item {
    padding-right:  10rpx;
}
onReachBottom:function (){
    this.setData({imglist:this.data.imglist.concat(list)
  })
}

基本思路就是利用wx:if和数组的下标对2取余来判断是排在左列还是排在右列,这里面很重要的一个属性就是mode='widthFix',即表示图片宽度固定,高度自适应,由此即可实现效果。
最后在函数onReachBottom中修改数据即可实现上拉加载。当然实现瀑布流的方法有很多,查了一下通过css3中属性column-count也可以实现同样的效果。


链接: https://fly63.com/article/detial/7599

vue实现瀑布流布局的组件/插件总汇

瀑布流作为当前比较流行的一种网页布局方式,在视觉上呈现出参差不齐、琳琅满目、唯美的视觉效果,该布局随着页面滚动,数据不断加载并附加至当前页面的尾部。这篇文章主要介绍关于vue框架中常使用的瀑布流组件

CSS3实现瀑布流布局

瀑布流布局是种常见的布局方式,常用于图片相关的样式展示,通过CSS3的多列(Multi-column)属性,可以简单的实现类似效果。设置外部容器多列列数(column-count)和列间距(column-gap)

js实现无限瀑布流

是一种常见的网页布局方式,在许多网站中我们都能看到“瀑布流”的效果,其特征是有网页视窗有多个高度不同宽度相同的“块”组成。因其样式酷似飞流直下的瀑布,故将这种布局方式称为瀑布流。

瀑布流的布局原理分析(纯CSS瀑布流与JS瀑布流)

瀑布流 又称瀑布流式布局,是比较流行的一种网站页面布局方式。即多行等宽元素排列,后面的元素依次添加到其后,等宽不等高,根据图片原比例缩放直至宽度达到我们的要求,依次按照规则放入指定位置。

万能瀑布流

常见的瀑布流实现大部分只适用于子块尺寸固定或内部有图片异步加载的情况。而对于子块有图片这种可能引起尺寸变化的情况,通常的做法是写死图片高度,或检测内部的 img 元素从而在 onload 事件中进行重排。

原生JS实现一个瀑布流插件

瀑布流布局中的图片有一个核心特点 —— 等宽不定等高,瀑布流布局在国内网网站都有一定规模的使用,比如pinterest、花瓣网等等。那么接下来就基于这个特点开始瀑布流探索之旅。

纯CSS瀑布流与JS瀑布流

又称瀑布流式布局,是比较流行的一种网站页面布局方式。即多行等宽元素排列,后面的元素依次添加到其后,等宽不等高,根据图片原比例缩放直至宽度达到我们的要求,依次按照规则放入指定位置。

vue实现网络图片瀑布流 + 下拉刷新 + 上拉加载更多

用vue来实现一个瀑布流效果,加载网络图片,同时有下拉刷新和上拉加载更多功能效果。然后针对这几个效果的实现,捋下思路:根据加载数据的顺序,依次追加标签展示效果;

JavaScript实现简单的图片瀑布流插件

JavaScript实现简单的图片瀑布流插件,功能:1).可以自动根据浏览器视口宽度,改变图片瀑布流的宽度2).添加了函数防抖功能

css实现瀑布流布局

依赖 column 便可实现最简单实用的瀑布流布局,我这里前端框架用的是 Vue, 用其他的也一样,column-count: 3; 内容均分三份

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!