CSS瀑布流实现

news/2024/9/17 3:34:51/ 标签: css, 前端

文章目录

    • 前言
      • 前置知识
    • React 中实现
      • 代码实现
    • Vue 中实现
      • 代码实现

前言

瀑布流是一种CSS布局技术,它允许不同高度的元素在页面上以美观的方式排列,同时保持行与列间的间距一致。

前置知识

  1. 使用 multi-column 实现多列布局
  • column-count: 设置布局显示的列数。
  • column-gap: 定义列与列之间的间距。
  • column-rule: 设置列与列之间的边框样式。
  • column-fill: 控制如何填充列,当内容高度不均时是否平衡各列的高度。
  1. break-inside 属性

该属性用于控制块级元素的内容是否可以在其内部断开:

  • auto: 默认值,允许内容在元素内部正常断开。
  • avoid: 尝试避免在元素内部断开。如果内容过大而无法适应当前容器,则可能会导致溢出,而不是断开。
  • avoid-page: 在打印或分页媒体中,避免在元素内部开始新的页面。

React 中实现

代码实现

import { useState } from "react";
import less from "./index.module.css";const Falls = () => {const [data] = useState(["紫荆花飘扬紫荆花飘扬紫荆花飘扬紫荆花飘扬紫荆花飘扬紫荆花飘扬","飞向 避风的海港避风的海港避风的海港避风的海港避风的海港避风的海港避风的海港","摇曳 一湾水温柔","全是 最爱坚守","纯真 是你的微笑是你的微笑是你的微笑是你的微笑是你的微笑是你的微笑","一眼到永远的抱抱","爱像 亲恩般深长",]);return (<div className={less.page}><div className={less.card_container}>{data.map((item) => (<div key={item} className={less.card_item}>{/* 需要显示的内容 */}{item}</div>))}</div></div>);
};export default Falls;
css">.page {width: 100vw;min-height: 100vh;overflow: hidden;padding: 10px 16px;box-sizing: border-box;
}.card_container {column-count: 2; column-gap: 15px; 
}.card_item {break-inside: avoid; margin-bottom: 15px;padding: 10px;box-sizing: border-box;border: 1px solid #9999994e;box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

效果展示
在这里插入图片描述

Vue 中实现

代码实现

<template><div class="page"><div class="card-container"><div class="card-item" v-for="item in data" :key="item">{{ item }}</div></div></div>
</template><script setup>const data = ["紫荆花飘扬紫荆花飘扬紫荆花飘扬紫荆花飘扬紫荆花飘扬紫荆花飘扬", "飞向 避风的海港避风的海港避风的海港避风的海港避风的海港避风的海港避风的海港", "摇曳 一湾水温柔", "全是 最爱坚守", "纯真 是你的微笑是你的微笑是你的微笑是你的微笑是你的微笑是你的微笑", "一眼到永远的抱抱", "爱像 亲恩般深长"]</script><style lang="scss" scoped>
.page {width: 100vw;min-height: 100vh;overflow: hidden;padding: 10px 16px;box-sizing: border-box;.card-container {column-count: 2; // 定义2列column-gap: 15px; // 列与列的距离为20px.card-item {break-inside: avoid; // 指定元素不被截断margin-bottom: 15px;padding: 10px;box-sizing: border-box;border: 1px solid #9999994e;box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);}}
}
</style>

效果展示
在这里插入图片描述


http://www.ppmy.cn/news/1522333.html

相关文章

MongoDB 的适用场景

MongoDB 的适用场景 MongoDB 是一种基于文档存储的 NoSQL 数据库&#xff0c;与传统的关系型数据库不同&#xff0c;它使用 JSON 类似的二进制文档格式&#xff08;BSON&#xff09;来存储数据&#xff0c;并且具备灵活的文档模型、强大的查询能力和水平扩展性。这些特性使得 …

音乐项目

获取验证码&#xff1a; 将获取验证码的消息发送给前端&#xff0c;再由后端发给前端 function getverification_code(event) {event.preventDefault();console.log(点击获取验证码按钮);// 获取输入元素的值const emailInput document.getElementById(email);const emailVal…

Leetcode JAVA刷刷站(112)路径总和

一、题目概述 二、思路方向 为了解决这个问题&#xff0c;我们可以使用深度优先搜索&#xff08;DFS&#xff09;算法来遍历二叉树&#xff0c;并检查从根节点到叶子节点的路径和是否等于目标和。 三、代码实现 class TreeNode { int val; TreeNode left; TreeNode rig…

架构全景视图

文章目录 一、战略规划二、业务架构Business Architecture2.1业务架构定义2.2 业务架构组成2.3 TOGAF2.3.1 Archimate建模&#xff08;重要&#xff09; 三、数据架构Data Architecture3.1 数据架构定义3.2 数据架构组成 四、应用架构Application Architecture4.1 应用架构定义…

相亲交友系统商业开发

在快节奏的现代生活中&#xff0c;寻找真爱成为了许多人的渴望。相亲交友系统&#xff0c;作为连接心灵的桥梁&#xff0c;正逐渐成为人们寻找伴侣的首选方式。我们的团队h17711347205致力于开发一款创新的相亲交友系统&#xff0c;旨在通过智能化的匹配算法&#xff0c;为用户…

The Prompt Report 2

The Prompt Report 提示工程调查报告《The Prompt Report: A Systematic Survey of Prompting Techniques》 主要内容 Core Prompting Techniques Text based Techniques&#xff1a;PRISMA流程&#xff0c;58中基于文本的提示技术&#xff0c;提示语术语分类表&#xff1b;M…

java opencv no opencv_java490 in java.library.path

java使用opencv处理图片&#xff0c;idea运行程序&#xff0c;报错异常信息&#xff1a; Exception in thread "main" java.lang.UnsatisfiedLinkError: no opencv_java490 in java.library.path: /Users/carter/Library/Java/Extensions:/Library/Java/Extensions:…

知名数字化增长战略研究学者专家教授顾问培训讲师唐兴通增长战略增长结构增长机会

唐兴通 数字化商业创新顾问、数字营销专家、数字化转型教练、沃顿商学院演讲嘉宾。全球商业思想大家EM罗杰斯&#xff08;创新的扩散&#xff09;、杰弗里摩尔&#xff08;跨越鸿沟&#xff09;、马修狄克逊&#xff08;挑战式销售&#xff09;、布兰登博格&#xff08;竞合战…

❤《实战纪录片 1 》原生开发小程序中遇到的问题和解决方案

《实战纪录片 1 》原生开发小程序中遇到的问题和解决方案 文章目录 《实战纪录片 1 》原生开发小程序中遇到的问题和解决方案1、问题一&#xff1a;原生开发中 request请求中返回 的数据无法 使用this传递给 data{}中怎么办&#xff1f;2、刚登录后如何将token信息保存&#xf…

最新版 | 深入剖析SpringBoot3源码——分析自动装配原理(面试常考)

文章目录 一、自动配置概念二、半自动配置&#xff08;误~&#x1f64f;&#x1f64f;&#xff09;三、源码分析1、验证DispatcherServlet的自动配置2、源码分析入口SpringBootApplication3、SpringBootConfiguration的Configuration4、EnableAutoConfiguration的AutoConfigura…

【C语言】详解数组

文章目录 前言一、数组的概念二、一维数组1.一维数组的创建2.一维数组的初始化3. 一维数组的使用4.一维数组在内存中的存储 三、二维数组1.二维数组的创建2. 二维数组的初始化3. 二维数组的使用4.二维数组在内存中的存储 前言 一、数组的概念&#xff08;数组是一组相同类型元素…

Codeforces Round (Div.3) C.Sort (前缀和的应用)

原题&#xff1a; time limit per test&#xff1a;5 seconds memory limit per test&#xff1a;256 megabytes You are given two strings a and b of length n. Then, you are (forced against your will) to answer q queries. For each query, you are given a range …

【重学 MySQL】十四、显示表结构

【重学 MySQL】十四、显示表结构 使用DESCRIBE或DESC命令使用SHOW COLUMNS命令查询information_schema数据库使用SHOW CREATE TABLE命令总结 在MySQL中&#xff0c;查看或显示表结构是一个常见的需求&#xff0c;它可以帮助你了解表中包含哪些列、每列的数据类型、是否允许为空…

DUFS 文件服务器,简单好用的http文件共享服务器

DUFS 文件服务器&#xff0c;简单好用的http文件共享服务器 0b6eabb13654 sigoden/dufs:latest "/bin/dufs" 4 months ago Up 8 days 0.0.0.0:5000->5000/tcp, :::5000->5000/tcp dufs_server 1. 拉取Dufs Docker镜像 docker pull sigoden/dufs …

【机器学习】机器学习引领未来:赋能精准高效的图像识别技术革新

&#x1f4dd;个人主页&#x1f339;&#xff1a;Eternity._ &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; ❀目录 &#x1f50d;1. 引言&#x1f4d2;2. 机器学习基础与图像识别原理&#x1f341;机器学习概述&#xff1a;监督学习、无监督学习与强化学…

自定义Stater

一 什么是stater&#xff1f; 我们平时在导入依赖的时候&#xff0c;大部分导入的都是xxx-spring-boot-stater。那是因为它们都基于spring的规则将写好的框架定义成一个stater&#xff0c;这样方便springboot引用它们写好的功能。 那我们为什么也要自定义stater呢&#xff1f…

zabbix6.4连接邮箱发出警告

添加告警媒介 默认接收人: 故障级别:{TRIGGER.STATUS}。 服务器:【{HOSTNAME1} 】 发生:{TRIGGER.NAME} 故障! 注:默认接收人:相当于邮件的主题 默认信息:邮件的主题 告警主机:{HOSTNAME1} 告警时间:{EVENT.DATE} {EVENT.TIME} 告警等级:{TRIGGER.SEVERITY} 告警信息:{TRIGGER.…

Java开发笔记--通用消息组件设计(移动短信、华为短信、163邮件)

最近项目开发完了&#xff0c;整理梳理了一下框架&#xff0c;总结记录一下通用消息组件的设计。 项目中的消息的存在种类多样性&#xff1a;APP消息、短信、邮件、站内消息&#xff0c;短信的服务商又有多种。我们项目采用的是spirng cloud alibaba,于是把消息这块抽出来做成…

【OpenCV3】图像的翻转、图像的旋转、仿射变换之图像平移、仿射变换之获取变换矩阵、透视变换

1 图像的放大与缩小 2 图像的翻转 3 图像的旋转 4 仿射变换之图像平移 5 仿射变换之获取变换矩阵 6 透视变换 1 图像的放大与缩小 resize(src, dsize[, dst[, fx[, fy[, interpolation]]]]) src: 要缩放的图片dsize: 缩放之后的图片大小, 元组和列表表示均可.dst: 可选参数, 缩…

前端跨域问题详解与解决方案指南

什么是跨域问题 跨域问题通常是由浏览器的同源策略&#xff08;Same-OriginPolicy&#xff0c;SOP&#xff09;引起的访问问题 同源策略是浏览器的一个重要安全机制&#xff0c;它用于限制一个来源的文档或脚本如何能够与另一个来源的资源进行交互 同源策略的定义 同源策略要…