前端过渡动画
创始人
2024-11-12 08:07:27
0

前端过渡动画

vue3

1、组件进入视口时向上移动且渐显

1、创建js文件addViewportEffect.js

function slideDownEffect(element) {     console.log("执行");     element.style.transform = 'translateY(0)';     element.style.opacity = '1'; }  /**  * 添加视口效果到指定的类名元素上。  * @param {string} className - 要添加效果的元素的类名。  * @param {Function} [effectFunction=slideDownEffect] - 当元素即将进入视口时要执行的动画效果函数。  * @param {string} [animatedClass='animated'] - 标记元素已执行动画效果的类名。  */ function addViewportEffect(className, effectFunction = slideDownEffect, animatedClass = 'animated') {     document.addEventListener('DOMContentLoaded', function() {         var elements = document.querySelectorAll(className);          function isInViewport(el) {             var rect = el.getBoundingClientRect();             var viewportBottom = window.innerHeight || document.documentElement.clientHeight;             return rect.top <= viewportBottom;         }          function checkElements() {             elements.forEach(function(el) {                 if (isInViewport(el) && !el.classList.contains(animatedClass)) {                     effectFunction(el);                     el.classList.add(animatedClass); // 标记元素已执行动画效果                 }             });         }          // 使用IntersectionObserver代替scroll事件监听器         const observer = new IntersectionObserver((entries, observer) => {             entries.forEach(entry => {                 if (entry.isIntersecting) {                     const element = entry.target;                     effectFunction(element);                     element.classList.add(animatedClass); // 动画完成后标记                     observer.unobserve(element); // 动画完成后取消对该元素的观察                 }             });         }, {             threshold: 0.1 // 在元素10%进入视口时触发         });          elements.forEach(el => {             observer.observe(el);         });     }); }  // 导出函数,以便在其他文件中使用 export default addViewportEffect;  

2、使用

先到需要这个效果的组件上创建一个class,内容如下:

.dx-01{   opacity: 0;   transform: translateY(200px);   transition: opacity 1s ease-in-out, transform 1s ease-in-out; } 
这是要执行效果的组件内容

然后在导入上面 js 的方法,并在页面创建时使用

 

js方法可复用,记得每次设置不同的class才行,不然会重复。

相关内容

热门资讯

突发!天天贵阳app修改器,天... 突发!天天贵阳app修改器,天天海南家园辅助(原来有挂插件)-哔哩哔哩进入游戏-大厅左侧-新手福利-...
据权威媒体报道!随意玩辅助器透... 据权威媒体报道!随意玩辅助器透视挂,新西部外卦辅助器(果然真的有挂)-哔哩哔哩;1、随意玩辅助器透视...
此事迅速冲上热搜!微乐自建房脚... 此事迅速冲上热搜!微乐自建房脚本免费下载,欢聚水鱼智能辅助教程(本来是真的脚本)-哔哩哔哩微乐自建房...
昨日!心悦俱乐部游戏辅助,欢乐... 昨日!心悦俱乐部游戏辅助,欢乐达人破解器(其实是有脚本)-哔哩哔哩1、下载好心悦俱乐部游戏辅助透视辅...
现就发布提示!广西友乐解码器辅... 现就发布提示!广西友乐解码器辅助器,圣游牛牛辅助器(果然有挂修改器)-哔哩哔哩1、玩家可以在广西友乐...
据相关数据显示!边锋辅助脚本,... 据相关数据显示!边锋辅助脚本,决战卡五星游戏辅助器(果然是真的脚本)-哔哩哔哩亲,关键说明,决战卡五...
连日来!微信小程序多乐辅助器免... 连日来!微信小程序多乐辅助器免费下载,人海大厅挂件怎么买(切实真的有修改器)-哔哩哔哩一、微信小程序...
最新消息!潮汕汇游戏辅助,湖北... 最新消息!潮汕汇游戏辅助,湖北逍遥辅助(都是真的有下载)-哔哩哔哩1、超多福利:超高返利,海量正版游...
经核实!广丰510k辅助,心悦... 经核实!广丰510k辅助,心悦游戏辅助(好像是有插件)-哔哩哔哩一、心悦游戏辅助可以开透视的定义与意...
经核实!南通长牌有挂吗,蜀山辅... 经核实!南通长牌有挂吗,蜀山辅助工具(确实真的是有脚本)-哔哩哔哩进入游戏-大厅左侧-新手福利-激活...