瀑布流 Waterfall
瀑布流展示图片列表
说明
宽度固定,图片等比例缩放;使用JS获取每张图片宽度和高度,结合 relative
和 absolute
定位计算每个图片的位置 top
,left
,保证每张新的图片都追加在当前高度最小的那列末尾
基本使用
Show Code
vue
<script setup lang="ts">
import { ref, onBeforeMount } from 'vue'
import type { WaterfallImage } from 'vue-amazing-ui'
const images = ref<WaterfallImage[]>([])
function loadImages() {
for (let i = 1; i <= 10; i++) {
images.value.push({
name: `image-${i}`,
src: `https://cdn.jsdelivr.net/gh/themusecatcher/resources@0.0.5/${i}.jpg`,
link: `https://cdn.jsdelivr.net/gh/themusecatcher/resources@0.0.5/${i}.jpg`
})
}
}
onBeforeMount(() => { // 组件已完成响应式状态设置,但未创建DOM节点
loadImages()
})
</script>
<template>
<Waterfall :images="images" />
</template>
瀑布流配置器
Show Code
vue
<script setup lang="ts">
import { ref, onBeforeMount, reactive } from 'vue'
import type { WaterfallImage } from 'vue-amazing-ui'
const images = ref<WaterfallImage[]>([])
const state = reactive({
columnCount: 3,
columnGap: 20,
backgroundColor: '#e6f4ff',
borderRadius: 12
})
function loadImages() {
for (let i = 1; i <= 10; i++) {
images.value.push({
name: `image-${i}`,
src: `https://cdn.jsdelivr.net/gh/themusecatcher/resources@0.0.5/${i}.jpg`,
link: `https://cdn.jsdelivr.net/gh/themusecatcher/resources@0.0.5/${i}.jpg`
})
}
}
onBeforeMount(() => { // 组件已完成响应式状态设置,但未创建DOM节点
loadImages()
})
</script>
<template>
<Row :gutter="24">
<Col :span="6">
<Flex vertical gap="middle">
columnCount:
<Slider :min="1" :max="6" v-model:value="state.columnCount" />
</Flex>
</Col>
<Col :span="6">
<Flex vertical gap="middle">
columnGap:
<Slider :min="10" :max="100" v-model:value="state.columnGap" />
</Flex>
</Col>
<Col :span="6">
<Flex vertical gap="middle">
borderRadius:
<Slider :min="0" :max="100" v-model:value="state.borderRadius" />
</Flex>
</Col>
<Col :span="6">
<Flex vertical>
backgroundColor:
<ColorPicker v-model:value="state.backgroundColor" />
</Flex>
</Col>
</Row>
<Waterfall
class="mt30"
:images="images"
:column-count="state.columnCount"
:column-gap="state.columnGap"
:background-color="state.backgroundColor"
:border-radius="state.borderRadius"
/>
</template>
<style lang="less" scoped>
.mt30 {
margin-top: 30px;
}
</style>
APIs
Waterfall
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
images | 图片数组 | Image[] | [] |
columnCount | 要划分的列数 | number | 3 |
columnGap | 各列之间的间隙,单位 px | number | 20 |
width | 瀑布流区域的总宽度 | string | number | '100%' |
borderRadius | 瀑布流区域和图片圆角,单位 px | number | 8 |
backgroundColor | 瀑布流区域背景填充色 | string | '#F2F4F8' |
spinProps | Spin 组件属性配置,参考 Spin Props,用于配置图片加载中样式 | object | {} |
Image Type
名称 | 说明 | 类型 | 默认值 |
---|---|---|---|
name? | 图片名称 | string | undefined |
src | 图片地址 | string | undefined |
link? | 图片跳转链接 | string | undefined |
target? | 如何打开跳转链接 | '_self' | '_blank' | undefined |