前端过渡动画
创始人
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(透视)透牌教程(2022已更新)(哔哩哔哩)是一款可以让一直输...
3分钟了解(九线拉王)外挂透明... 您好,九线拉王这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏...
九分钟了解(爱玩信阳黑七)外挂... 九分钟了解(爱玩信阳黑七)外挂辅助软件(透视)详细教程(2026已更新)(哔哩哔哩)是一款可以让一直...
第4分钟了解(小南娱乐)外挂透... 第4分钟了解(小南娱乐)外挂透明挂辅助工具(透视)安装教程(2026已更新)(哔哩哔哩);小南娱乐最...
第9分钟了解(wpk发牌)外挂... 第9分钟了解(wpk发牌)外挂辅助神器(辅助挂)新2025教程(2020已更新)(哔哩哔哩);wpk...
5分钟了解(wepoke真的有... 您好,wepoke真的有挂这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩...
五分钟了解(湘叶娱乐)外挂透明... 五分钟了解(湘叶娱乐)外挂透明挂辅助app(辅助挂)辅助教程(2020已更新)(哔哩哔哩);人气非常...
第七分钟了解(挖坑青海麻将)外... 第七分钟了解(挖坑青海麻将)外挂辅助app(透视)2025新版(2023已更新)(哔哩哔哩);超受欢...
第4分钟了解(天天黄石麻将)外... 第4分钟了解(天天黄石麻将)外挂辅助插件(透视)AI教程(2025已更新)(哔哩哔哩)是一款可以让一...
2分钟了解(福来)外挂辅助器(... 2分钟了解(福来)外挂辅助器(辅助挂)安装教程(2023已更新)(哔哩哔哩);亲,有的,ai轻松简单...