vue实现瀑布流

  1. 每个色块宽度一致,高度自适应
<!DOCTYPE html>
<html><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><meta name="renderer" content="webkit"><meta name="viewport" content="user-scalable=0"><title>Vertical Line</title><link rel="stylesheet" href="./common/css/style.css"><style>.item-move {transition: all .5s cubic-bezier(.55, 0, .1, 1);-webkit-transition: all .5s cubic-bezier(.55, 0, .1, 1);}</style>
</head><body><div id="app"><waterfall :align="align" :line-gap="200" :min-line-gap="100" :max-line-gap="220" :single-max-width="300":watch="items" @reflowed="reflowed" ref="waterfall"><!-- each component is wrapped by a waterfall slot --><waterfall-slot v-for="(item, index) in items" :width="item.width" :height="item.height" :order="index":key="item.index" move-class="item-move"><div class="item" :style="item.style" :index="item.index"></div></waterfall-slot></waterfall></div><script src="https://cdn.jsdelivr.net/vue/2.2.6/vue.min.js"></script><script src="http://app.moptym.com/cdn/vue-waterfall/vue-waterfall.min.js"></script><script src="./common/js/item-factory.js"></script><script>var app = new Vue({el: '#app',components: {'waterfall': Waterfall.waterfall,'waterfall-slot': Waterfall.waterfallSlot},data: {align: 'center',items: ItemFactory.get(100),isBusy: false},methods: {addItems: function () {if (!this.isBusy && this.items.length < 500) {this.isBusy = truethis.items.push.apply(this.items, ItemFactory.get(50))}},shuffle: function () {this.items.sort(function () {return Math.random() - 0.5})},reflowed: function () {this.isBusy = false}}})document.body.addEventListener('click', function () {app.shuffle()// app.$refs.waterfall.$emit('reflow') // manually trigger reflow action}, false)window.addEventListener('scroll', function () {var scrollTop = document.documentElement.scrollTop || document.body.scrollTopif (scrollTop + window.innerHeight >= document.body.clientHeight) {app.addItems()}})</script>
</body></html>

如图所示:
在这里插入图片描述

  1. 每个色块高度一致,宽度自适应
<!DOCTYPE html>
<html><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><meta name="renderer" content="webkit"><meta name="viewport" content="user-scalable=0"><title>Horizontal Line</title><link rel="stylesheet" href="./common/css/style.css"><style>.item-move {transition: all .5s cubic-bezier(.55, 0, .1, 1);-webkit-transition: all .5s cubic-bezier(.55, 0, .1, 1);}</style>
</head><body><div id="app"><waterfall :line="line" :line-gap="200" :min-line-gap="180" :max-line-gap="220" :watch="items" @reflowed="reflowed"ref="waterfall"><!-- each component is wrapped by a waterfall slot --><waterfall-slot v-for="(item, index) in items" :width="item.width" :height="item.height" :order="index":key="item.index" move-class="item-move"><div class="item" :style="item.style" :index="item.index"></div></waterfall-slot></waterfall></div><script src="https://cdn.jsdelivr.net/vue/2.2.6/vue.min.js"></script><script src="http://app.moptym.com/cdn/vue-waterfall/vue-waterfall.min.js"></script><script src="./common/js/item-factory.js"></script><script>var app = new Vue({el: '#app',components: {'waterfall': Waterfall.waterfall,'waterfall-slot': Waterfall.waterfallSlot},data: {line: 'h',items: ItemFactory.get(100),isBusy: false},methods: {addItems: function () {if (!this.isBusy && this.items.length < 500) {this.isBusy = truethis.items.push.apply(this.items, ItemFactory.get(50))}},shuffle: function () {this.items.sort(function () {return Math.random() - 0.5})},reflowed: function () {this.isBusy = false}}})document.body.addEventListener('click', function () {app.shuffle()// app.$refs.waterfall.$emit('reflow') // manually trigger reflow action}, false)window.addEventListener('scroll', function () {var scrollTop = document.documentElement.scrollTop || document.body.scrollTopif (scrollTop + window.innerHeight >= document.body.clientHeight) {app.addItems()}})</script>
</body></html>

如图所示:
在这里插入图片描述

  1. 宽高不限制,每个色块顺着排
<!DOCTYPE html>
<html><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><meta name="renderer" content="webkit"><meta name="viewport" content="user-scalable=0"><title>Vertical Line With Grow</title><link rel="stylesheet" href="./common/css/style.css"><style>.item-move {transition: all .5s cubic-bezier(.55, 0, .1, 1);-webkit-transition: all .5s cubic-bezier(.55, 0, .1, 1);}</style>
</head><body><div id="app"><waterfall :grow="grow" :watch="items" @reflowed="reflowed" ref="waterfall"><!-- each component is wrapped by a waterfall slot --><waterfall-slot v-for="(item, index) in items" :width="item.width" :height="item.height" :order="index":key="item.index" move-class="item-move"><div class="item" :style="item.style" :index="item.index"></div></waterfall-slot></waterfall></div><script src="https://cdn.jsdelivr.net/vue/2.2.6/vue.min.js"></script><script src="http://app.moptym.com/cdn/vue-waterfall/vue-waterfall.min.js"></script><script src="./common/js/item-factory.js"></script><script>var app = new Vue({el: '#app',components: {'waterfall': Waterfall.waterfall,'waterfall-slot': Waterfall.waterfallSlot},data: {grow: [3, 2, 1, 2],items: ItemFactory.get(100),isBusy: false},methods: {addItems: function () {if (!this.isBusy && this.items.length < 500) {this.isBusy = truethis.items.push.apply(this.items, ItemFactory.get(50))}},shuffle: function () {this.items.sort(function () {return Math.random() - 0.5})},reflowed: function () {this.isBusy = false}}})document.body.addEventListener('click', function () {app.shuffle()// app.$refs.waterfall.$emit('reflow') // manually trigger reflow action}, false)window.addEventListener('scroll', function () {var scrollTop = document.documentElement.scrollTop || document.body.scrollTopif (scrollTop + window.innerHeight >= document.body.clientHeight) {app.addItems()}})</script>
</body></html>

如图所示:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/251943.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32F407移植OpenHarmony笔记7

继上一篇笔记&#xff0c;成功启动了liteos_m内核&#xff0c;可以创建线程了&#xff0c;也能看到shell控制台了。 今天研究文件系统&#xff0c;让控制台相关文件命令如mkdir和ls能工作。 liteos_m内核支持fatfs和littlefs两个文件系统&#xff0c; fatfs适用于SD卡&#xff…

【C++】C++入门 — 类和对象初步介绍

类和对象 1 类的作用域2 类的实例化3 类对象模型4 this指针介绍&#xff1a;特性&#xff1a; Thanks♪(&#xff65;ω&#xff65;)&#xff89;谢谢阅读&#xff01;下一篇文章见&#xff01;&#xff01;&#xff01; 1 类的作用域 类定义了一个新的作用域&#xff0c;类的…

指针的深入理解(四)

这节主要讨论sizeof和strlen的区别&#xff0c;以及一些理解题。 sizeof 求的是对象的大小&#xff0c;深入理解一点就是&#xff1a;这个对象&#xff0c;他一定有一块对应的内存空间。求的就是这一块内存空间。 strlen 只能用来求字符串&#xff0c; 求取的是字符串的长度。…

QT 范例阅读:系统托盘 The System Tray Icon example

main.cpp QApplication app(argc, argv);//判断系统是否支持 系统托盘功能if (!QSystemTrayIcon::isSystemTrayAvailable()) {QMessageBox::critical(0, QObject::tr("Systray"),QObject::tr("I couldnt detect any system tray ""on this system.&qu…

【C++】开源:Windows图形库EasyX配置与使用

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍Windows图形库EasyX配置与使用。 无专精则不能成&#xff0c;无涉猎则不能通。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&#…

Linux进程信号(2)--信号的保存

目录 1.阻塞信号 1.1 信号其他相关常见概念 1.实际执行信号的处理动作称为信号递达(Delivery&#xff09; 2.信号从产生到递达之间的状态,称为信号未决(Pending)。 3.进程可以选择阻塞 (Block )某个信号。 1.2信号在内核中的表示 sigset_t 信号集操作函数 使用sigprocm…

nginx slice模块的使用和源码分析

文章目录 1. 为什么需要ngx_http_slice_module2. 配置指令3. 加载模块4. 源码分析4.1 指令分析4.2 模块初始化4.3 slice模块的上下文4.2 $slice_range字段值获取4.3 http header过滤处理4.4 http body过滤处理5 测试和验证 1. 为什么需要ngx_http_slice_module 顾名思义&#…

Vue中keep-alive的作用、原理及应用场景

在进行Vue开发的过程中&#xff0c;我们经常会遇到需要进行组件缓存的场景&#xff0c;这时候Vue提供的keep-alive组件就派上了用场。keep-alive组件是Vue内置的一个抽象组件&#xff0c;它可以将其包裹的组件进行缓存&#xff0c;提高组件的性能&#xff0c;同时也可以节省服务…

普渡机器人CEO预测2024年服务机器人市场将扩大

原创 | 文 BFT机器人 根据普渡科技有限公司的报告&#xff0c;商用服务机器人在东亚地区的应用比其他地方更为广泛。然而&#xff0c;预计到2024年&#xff0c;全球其他地区也将迎头赶上。这家总部位于中国深圳的公司自豪地宣称&#xff0c;它已经成为中国最大的此类机器人出口…

前端excel带样式导出 exceljs 插件的使用

本来用的xlsx和xlsx-style两个插件&#xff0c;过程一步一个坑&#xff0c;到完全能用要消灭好多bug。这时发现了exceljs&#xff0c;真香&#x1f600; 案例 <!DOCTYPE html> <html><head><meta charset"utf-8" /><meta name"view…

详解WebRTC rtc::Thread实现

rtc::Thread介绍 rtc::Thread类不仅仅实现了线程这个执行器&#xff08;比如posix底层调用pthread相关接口创建线程&#xff0c;管理线程等&#xff09;&#xff0c;还包括消息队列&#xff08;message_queue)的实现&#xff0c;rtc::Thread启动后就作为一个永不停止的event l…

如何使用MCSM搭建我的世界Java版服务器并实现远程联机游戏

文章目录 1. 安装JAVA2. MCSManager安装3.局域网访问MCSM4.创建我的世界服务器5.局域网联机测试6.安装cpolar内网穿透7. 配置公网访问地址8.远程联机测试9. 配置固定远程联机端口地址9.1 保留一个固定tcp地址9.2 配置固定公网TCP地址9.3 使用固定公网地址远程联机 本教程主要介…

c语言实现greedy snake(贪吃蛇)

##第一个小项目 大一学生寒假项目 最终实现效果如图 一.以C语言实现个人小项目 在我们快速学完了一个高级编程语言&#xff0c;就应该写一个小项目来加以巩固自己的学习成果。 所以今天&#xff0c;我们来尝试写一写greedy snake&#xff0c;对于大学生来说也是可以加强能…

2,cdc放缩位图

类似地&#xff0c;用pDC->StretchBlt来缩放&#xff0c;只是加上了两个参数&#xff0c;原始位图的宽高。 void CMy1_showbitmapView::StretchBitMap(CDC * pDC) { //CBitmap对象 CBitmap bitmap; //CDC对象 CDC dcMemory; //加载资源 bitmap.LoadBitmapW(IDB_BITMAP1); /…

JUnit

前言&#xff1a;自动化就是selenium脚本来实现的&#xff0c;JUnit是java的单元测试工具&#xff0c;只不过我们在实现自动化的时候需要借助一下JUnit库里面提供的一些方法。 目录 1、Test 2、断言—Assertions类 3、用例的执行顺序 3.1 通过order注解来排序 3.2 参数化 …

delete、truncate和drop区别

一、从执行速度上来说 drop > truncate >> DELETE 二、从原理上讲 1、DELETE DELETE from TABLE_NAME where xxx1.1、DELETE属于数据库DML操作语言&#xff0c;只删除数据不删除表的结构&#xff0c;会走事务&#xff0c;执行时会触发trigger&#xff08; 触发器…

ChatGPT之搭建API代理服务

简介 一行Docker命令部署的 OpenAI/GPT API代理&#xff0c;支持SSE流式返回、腾讯云函数 。 项目地址&#xff1a;https://github.com/easychen/openai-api-proxy 这个项目可以自行搭建 OpenAI API 代理服务器工具&#xff0c;该项目是代理的服务器端&#xff0c;不是客户端。…

IP数据云识别真实IP与虚假流量案例

随着互联网的普及&#xff0c;企业在数字领域面临着越来越复杂的网络威胁。为了保护网站免受虚假流量和恶意攻击的影响&#xff0c;许多企业正在采用IP数据云。本文将结合一个真实案例&#xff0c;深入探讨IP数据云如何成功准确地识别真实用户IP和虚假流量IP&#xff0c;提高网…

【数据分享】1929-2023年全球站点的逐日降雪深度数据(Shp\Excel\免费获取)

气象数据是在各项研究中都经常使用的数据&#xff0c;气象指标包括气温、风速、降水、能见度等指标&#xff0c;说到气象数据&#xff0c;最详细的气象数据是具体到气象监测站点的数据&#xff01; 之前我们分享过1929-2023年全球气象站点的逐日平均气温数据、逐日最高气温数据…

计算机网络_1.6.1 常见的三种计算机网络体系结构

1.6.1 常见的三种计算机网络体系结构 1、OSI&#xff08;七层协议&#xff09;标准失败的原因2、TCP/IP参考模型3、三种网络体系结构对比 笔记来源&#xff1a; B站 《深入浅出计算机网络》课程 1、OSI&#xff08;七层协议&#xff09;标准失败的原因 &#xff08;1&#xf…