前端原生 CSS 跑马灯效果,无限轮播(横竖版本,带渐变遮罩,简单实用)

news2024/11/28 10:36:56

一、横版跑马灯

Untitled.gif

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .box {
      /* 重点:盒子宽度 600 */
      width: 600px;
      height: 150px;
      border: 3px solid black;
      overflow: hidden;
    }
    .box ul {
      margin: 0;
      padding: 0;
      list-style: none;
      display: flex;
      height: 100%;
      animation: move 5s linear infinite;
    }
    /* hover 暂停,不用可去掉 */
    .box ul:hover {
      animation-play-state: paused;
    }
    .box ul li {
      height: 100%;
      /* 重点:单个图片宽度 200,相当于默认不动可见 3 个 */
      width: 200px;
      flex-shrink: 0;
    }
    .box ul li img {
      height: 100%;
      width: 100%;
    }
    @keyframes move {
      /* 为什么设置 -800px ?公式:主图张数 * 单个图片宽度(每轮主图只有 4 张,4 张照片为一个周期,如果需要轮播的主图为 7、8、9...张,都一样) */
      100% {
        transform: translateX(-800px);
      }
    }
  </style>
</head>
<body>
  <!-- 窗口 -->
  <div class="box">
    <!-- 轮播列表 -->
    <ul>
      <!-- 轮播主图 -->
      <li><a href="#"><img src="./1.jpg" alt=""></a></li>
      <li><a href="#"><img src="./2.jpg" alt=""></a></li>
      <li><a href="#"><img src="./3.jpg" alt=""></a></li>
      <li><a href="#"><img src="./4.jpg" alt=""></a></li>
      <!-- 轮播完成防止留白 -->
      <!-- 怎么确定尾部需要几张防止留白,3 张是怎么得出的?其实就是上面: 盒子宽度 / 单个图片宽度 = 一屏几张留白图 -->
      <li><a href="#"><img src="./1.jpg" alt=""></a></li>
      <li><a href="#"><img src="./2.jpg" alt=""></a></li>
      <li><a href="#"><img src="./3.jpg" alt=""></a></li>
    </ul>
</div>
</body>
</html>

二、竖版跑马灯

Untitled.gif

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .box {
      width: 600px;
      /* 重点:盒子宽度 150 */
      height: 150px;
      border: 3px solid black;
      overflow: hidden;
    }
    .box ul {
      margin: 0;
      padding: 0;
      list-style: none;
      display: flex;
      flex-direction: column;
      height: 100%;
      animation: move 5s linear infinite;
    }
    /* hover 暂停,不用可去掉 */
    .box ul:hover {
      animation-play-state: paused;
    }
    .box ul li {
      /* 重点:单个图片高度 150,相当于默认不动可见 1 个 */
      height: 150px;
      width: 100%;
      flex-shrink: 0;
    }
    .box ul li img {
      height: 100%;
      width: 100%;
    }
    @keyframes move {
      /* 为什么设置 -600px ?公式:主图张数 * 单个图片高度(每轮主图只有 4 张,4 张照片为一个周期,如果需要轮播的主图为 7、8、9...张,都一样) */
      100% {
        transform: translateY(-600px);
      }
    }
  </style>
</head>
<body>
  <!-- 窗口 -->
  <div class="box">
    <!-- 轮播列表 -->
    <ul>
      <!-- 轮播主图 -->
      <li><a href="#"><img src="./1.jpg" alt=""></a></li>
      <li><a href="#"><img src="./2.jpg" alt=""></a></li>
      <li><a href="#"><img src="./3.jpg" alt=""></a></li>
      <li><a href="#"><img src="./4.jpg" alt=""></a></li>
      <!-- 轮播完成防止留白 -->
      <!-- 怎么确定尾部需要几张防止留白,1 张是怎么得出的?其实就是上面: 盒子高度 / 单个图片高度 = 一屏几张留白图 -->
      <li><a href="#"><img src="./1.jpg" alt=""></a></li>
    </ul>
</div>
</body>
</html>

三、竖版跑马灯(带渐变遮罩,可以改成横向的)

Untitled.gif

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .box {
      position: relative;
      width: 600px;
      /* 重点:盒子宽度 150 */
      height: 150px;
      overflow: hidden;
    }
    .box ul {
      margin: 0;
      padding: 0;
      list-style: none;
      display: flex;
      flex-direction: column;
      height: 100%;
      animation: move 5s linear infinite;
    }
    /* hover 暂停,不用可去掉 */
    .box ul:hover {
      animation-play-state: paused;
    }
    .box ul li {
      /* 重点:单个图片高度 150,相当于默认不动可见 1 个 */
      height: 150px;
      width: 100%;
      flex-shrink: 0;
    }
    .box ul li img {
      height: 100%;
      width: 100%;
    }
    @keyframes move {
      /* 为什么设置 -600px ?公式:主图张数 * 单个图片高度(每轮主图只有 4 张,4 张照片为一个周期,如果需要轮播的主图为 7、8、9...张,都一样) */
      100% {
        transform: translateY(-600px);
      }
    }
    /* 顶部、底部白色渐变 */
    .header-blur {
      position: absolute;
      left: 0;
      top: 0;
      right: 0;
      height: 10px;
      /* background-image: linear-gradient(red, green 50%); */
      background-image: linear-gradient(#fff, rgba(0, 0, 0, 0) 50%);
      z-index: 1;
    }
    .footer-blur {
      position: absolute;
      left: 0;
      bottom: 0;
      right: 0;
      height: 10px;
      /* background-image: linear-gradient(red 40%, green); */
      background-image: linear-gradient(rgba(0, 0, 0, 0) 40%, #fff);
      z-index: 1;
    }
  </style>
</head>
<body>
  <!-- 窗口 -->
  <div class="box">
    <!-- 顶部、底部白色渐变 -->
    <div class="header-blur"></div>
    <div class="footer-blur"></div>
    <!-- 轮播列表 -->
    <ul>
      <!-- 轮播主图 -->
      <li><a href="#"><img src="./1.jpg" alt=""></a></li>
      <li><a href="#"><img src="./2.jpg" alt=""></a></li>
      <li><a href="#"><img src="./3.jpg" alt=""></a></li>
      <li><a href="#"><img src="./4.jpg" alt=""></a></li>
      <!-- 轮播完成防止留白 -->
      <!-- 怎么确定尾部需要几张防止留白,1 张是怎么得出的?其实就是上面: 盒子高度 / 单个图片高度 = 一屏几张留白图 -->
      <li><a href="#"><img src="./1.jpg" alt=""></a></li>
    </ul>
</div>
</body>
</html>

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Redis入门到实战-数据结构 (四、原理篇)

一、动态字符串SDS 我们都知道Redis中保存的Key是字符串&#xff0c;value往往是字符串或者字符串的集合。可见字符串是Redis中最常用的一种数据结构。 不过Redis没有直接使用C语言中的字符串&#xff0c;因为C语言字符串存在很多问题&#xff1a; 获取字符串长度的需要通过…

计算机网络之http07 http2,http3

HTTP1.2 http1.2都做了哪些优化 (1)头部压缩 使用HPACK压缩头部 头部冗长&#xff0c;大量重复字段 &#xff08;2&#xff09;二进制帧 将报文头部和内容字符编码改为二进制格式 字符编码未压缩 &#xff08;3&#xff09;并发传输 解决h1.1 队头阻塞问题&#xff0c;多车道 …

opencv通道的分离与合并

大家好&#xff0c;我是csdn的博主&#xff1a;lqj_本人 这是我的个人博客主页&#xff1a; lqj_本人的博客_CSDN博客-微信小程序,前端,python领域博主lqj_本人擅长微信小程序,前端,python,等方面的知识https://blog.csdn.net/lbcyllqj?spm1011.2415.3001.5343哔哩哔哩欢迎关注…

腾讯云 cos 字体在CDN上跨域处理

问题描述&#xff1a;项目中用到了字体的静态资源&#xff0c;把静态资源放到了腾讯云对象存储提供的 COS 上&#xff0c;同时启用它的CDN来加速。但是&#xff0c;调试的过程中发现报错&#xff1a;CSS加载字体跨域了&#xff0c;字体图标无法正常显示。 原因&#xff1a;字体…

torch.grid_sample

参考&#xff1a; 双线性插值的理论Pytorch grid_sample解析PyTorch中grid_sample的使用方法pytorch中的grid_sample()使用 查阅官方文档&#xff0c;TORCH.NN.FUNCTIONAL.GRID_SAMPLE grid_sample的函数签名如下所示&#xff0c;torch.nn.functional.grid_sample(input, gr…

Java设计模式总叙

文章目录基本概念设计模式的七大原则设计模式有哪些高频使用&经典的设计模式创建型-工厂方法模式创建型-建造者模式结构型-代理模式结构型-外观模式行为型-策略模式行为型-模板方法补充UML类图关系参考基本概念 使得代码编写真正工程化&#xff0c;它是软件工程的基石。 …

【cuda入门系列】通过代码真实打印线程ID

【cuda入门系列】通过代码真实打印线程ID1.gridDim(6,1),blockDim(4,1)2.gridDim(3,2),blockDim(2,2)【cuda入门系列之参加CUDA线上训练营】在Jetson nano本地跑 hello cuda&#xff01; 【cuda入门系列之参加CUDA线上训练营】一文认识cuda基本概念 【cuda入门系列之参加CUDA线…

ubuntu 20使用kubeadm安装k8s 1.26

步骤 机器&#xff1a;4核8G&#xff0c;root账号&#xff0c;可访问互联网 1、更新apt apt-get update 2、安装一些基本工具 apt-get install ca-certificates curl gnupg lsb-release net-tools apt-transport-https 3、ifconfig 获取ip&#xff0c;hostname获取主机名&…

【洛谷】P1195 口袋的天空

明显看出为最小生成树&#xff0c;那么&#xff1a;难点在哪里呢&#xff1f;if(cntn-k)//******{flag1;break;}为什么是cntn-k呢而不是k呢&#xff1f;&#xff01;&#xff01;&#xff01;解释&#xff1a;&#xff08;如果每个已经连在一起了就不能分开&#xff0c;不管多少…

【Kafka】【二十二】Kafka中Controller,Rebalance,HW,LEO的概念

Kafka中Controller&#xff0c;Rebalance&#xff0c;HW&#xff0c;LEO的概念 Controller 集群中谁来充当controller 每个broker启动时会向zk创建⼀个临时序号节点&#xff0c;获得的序号最⼩的那个broker将会作为集群中的controller&#xff0c;负责这么⼏件事&#xff1a;…

基于距离模型SE

知识表示 one-hot representation: 将研究对象表示为向量&#xff0c;该向量只有某一维度非零&#xff0c;其他维度上的值均为零。独热表示是信息检索和搜索引擎中广泛使用的词袋模型的基础&#xff0c;优点是无需学习过程。简单高效&#xff0c;在信息检索和自然语言处理中得…

亚马逊云科技助力滴普科技,加速企业数据价值洞察

随着企业数字化转型的不断深入&#xff0c;数据对于业务的价值和重要性也逐渐凸显。越来越多企业意识到&#xff0c;只有不断提升底层数据基础平台的性能和能力&#xff0c;才能构建数据驱动的业务&#xff0c;增强企业核心竞争力。作为湖仓一体数据智能基础软件独角兽企业&…

开学必备数码清单,大学生开学必备数码好物分享

还有很多小伙伴不知道开学应该准备什么&#xff0c;在学校当中需要用到的数码产品&#xff0c;在宿舍娱乐使用的音箱、学习当中使用到的笔记本&#xff0c;这些都是我们可以准备的&#xff0c;还有一个小众的好物&#xff0c;能够让我们在学校当中提升生活的幸福感&#xff0c;…

MinIO-rpm离线安装

近日&#xff0c;由于客户的系统运行环境在一个封闭的网络内&#xff0c;不能与互联网联通&#xff0c;也不能提供yum库&#xff0c;所以运行环境只能采用rpm离线安装的方式&#xff0c;我总结了一下本次的安装经过&#xff0c;希望对需要的人有所帮助。一、单机安装1.下载http…

postgres 源码解析49 Btree节点分裂点确认流程--2

上篇讲解了分裂的规则和填充策略等内容&#xff0c;而本文着重讲解postgres Btree分裂点确认流程&#xff0c;接口函数为 _bt_findsplitloc。相关知识点见回顾&#xff1a;postgres源码解析48 Btree节点分裂点确认流程–1 执行流程 _bt_findsplitloc 该函数的功能是确定该分裂…

金三银四一线大厂常见Java面试题面试题总结 1000+ 面试题

Java 面试八股文有必要背吗&#xff1f; 我的回答是&#xff1a;很有必要。你可以讨厌这种模式&#xff0c;但你一定要去背&#xff0c;因为不背你就进不了大厂。现如今&#xff0c;Java 面试的本质就是八股文&#xff0c;把八股文面试题背好&#xff0c;面试才有可能表现好。…

2020年欧空局10米土地覆盖数据

土地覆盖数据是我们平时最常用的地理数据之一&#xff0c;土地覆盖数据的来源也有很多种&#xff0c;之前我们介绍共过两个的30米精度的土地覆盖数据&#xff0c;分别为GlobeLand30土地覆盖数据和CLCD土地覆盖数据&#xff0c;&#xff08;可查看之前推送的文章&#xff09;&am…

Linux:用户空间非法指针coredump简析

1. 前言 限于作者能力水平&#xff0c;本文可能存在谬误&#xff0c;因此而给读者带来的损失&#xff0c;作者不做任何承诺。 2. 背景 本文分析基于 ARM32 架构&#xff0c;Linux-4.14 内核代码。 3. 问题分析 3.1 测试范例 void main(void) {*(int *)0 8; }运行程序会 …

Seata-Server分布式事务原理加源码 (七) - TCC事务模式

TCC事务模式 首先我们先来了解常规的TCC模式。 什么是TCC TCC 是分布式事务中的二阶段提交协议&#xff0c;它的全称为 Try-Confirm-Cancel&#xff0c;即资源预留&#xff08;Try&#xff09;、确认操作&#xff08;Confirm&#xff09;、取消操作&#xff08;Cancel&#…

CV——day77 简读论文:视频中交通标志的跟踪检测

视频中交通标志的跟踪检测Detection-by-tracking of traffic signs in videos1 Introduction3 Methods3.1 Faster R-CNN3.2 Proposed shortest-path approach3.3 Tractor-based method3.4 IoU-based method6 ConclusionsDetection-by-tracking of traffic signs in videos 视频…