长图边滚动边加载动画

1、背景

想要做一个酷炫的公司简介,使用一个长图介绍,可以一边滚动一边动态展示动画,让静态的页面看起来非常灵动。

2、技术路径

wow.js+animate.css

3、具体实现

(1)安装插件

js 复制代码
npm install wow.js --save

npm install animate.css --save

注意:安装时候版本有依赖,验证下来 "animate.css": "3.5""wowjs": "^1.1.3"是生效的。

(2)全局注册

main.js 复制代码
import 'animate.css'
import WOW from 'wowjs'

// 添加 WOW 实例到全局属性
app.config.globalProperties.$wow = new WOW.WOW({
  boxClass: 'wow',      // 默认类名
  animateClass: 'animated', // 默认动画类名前缀
  offset: 100,            // 距离视口多少像素时触发
  mobile: true,         // 是否在移动设备上启用
  live: true ,           // 对异步加载的内容是否有效
})

(3)页面引入和使用

初始化

index.js 复制代码
export default {
  name: "Index",
  data() {},
  created() {
  },
  mounted() {
    this.$wow.init()
  },
  methods: {}
}

在元素上直接写动画效果

index.vue 复制代码
<template>
  <div>
      <div class="zeroBgs">
      ....
      </div>
      <div class="oneBgs">
      <img src="../../assets/images/1-li1.png" data-wow-delay="0.1s" data-wow-offset="50" class="img-1-li1 wow fadeInRight" />
        <img src="../../assets/images/1-li2.png" data-wow-delay="0.1s" data-wow-offset="50" class="img-1-li2 wow fadeInLeft" />
        <img src="../../assets/images/1-li3.png" data-wow-delay="0.1s" data-wow-offset="50" class="img-1-li3 wow fadeInRight" />
        ....
      </div>
      ...

   </div>
 </template>

具体使用注意事项官网描述比较详细wow.jsanimate.css
data-wow-duration: 动画持续时间
data-wow-delay: 动画开始前的延迟
data-wow-offset: 开始动画的距离(与浏览器底部相关)
data-wow-iteration: 动画的次数重复(无限次:infinite)

具体动画效果可以看animate.css
注意:使用动画样式的时候需要带wow样式,即class类样式中需要包含wow。

至此,一个基本的长图一边手动滚动,一边加载动画的效果就完成了。

相关推荐
东风西巷1 小时前
Balabolka:免费高效的文字转语音软件
前端·人工智能·学习·语音识别·软件需求
萌萌哒草头将军1 小时前
10个 ES2025 新特性速览!🚀🚀🚀
前端·javascript·vue.js
半夏陌离1 小时前
SQL 入门指南:排序与分页查询(ORDER BY 多字段排序、LIMIT 分页实战)
java·前端·数据库
whysqwhw2 小时前
鸿蒙工程版本与设备版本不匹配
前端
gnip2 小时前
http缓存
前端·javascript
我不只是切图仔2 小时前
我只是想给网站加个注册验证码,咋就那么难!
前端·后端
该用户已不存在3 小时前
macOS是开发的终极进化版吗?
前端·后端
小豆包api3 小时前
小豆包AI API × Nano Banana:3D手办 + AI视频生成,「动起来」的神级玩法!
前端·api
布列瑟农的星空4 小时前
大话设计模式——观察者模式和发布/订阅模式的区别
前端·后端·架构
龙在天4 小时前
Vue3 实现 B站 视差 动画
前端