前端过渡动画
创始人
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才行,不然会重复。

相关内容

热门资讯

机巧辅助!大咖娱乐挂脚本(辅助... 您好,大咖娱乐挂脚本这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】很多玩家...
教材辅助!海米大厅辅助(辅助挂... 教材辅助!海米大厅辅助(辅助挂)好像真的是有辅助技巧(有挂技巧)1、不需要AI权限,帮助你快速的进行...
秘籍辅助!关春天开挂(辅助挂)... 您好,关春天开挂这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】很多玩家在这...
攻略辅助!威信茶馆透视器(辅助... 攻略辅助!威信茶馆透视器(辅助挂)好像存在有辅助app(存在有挂)1、首先打开威信茶馆透视器辅助器下...
教程书辅助!潮汕木虱有辅助挂吗... 教程书辅助!潮汕木虱有辅助挂吗(辅助挂)确实真的有辅助教程(有挂分析)小薇(辅助器软件下载)致您一封...
教材辅助!广东雀神祈福真的有用... 教材辅助!广东雀神祈福真的有用吗(辅助挂)都是真的有辅助器(发现有挂)1、让任何用户在无需广东雀神祈...
模块辅助!微信小游戏辅助器(辅... 您好,微信小游戏辅助器这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多玩...
妙招辅助!小程序牵手跑得快辅助... 妙招辅助!小程序牵手跑得快辅助器(辅助挂)其实存在有辅助器(有挂方式)1、小程序牵手跑得快辅助器脚本...
讲义辅助!同乡游有辅助软件吗(... 讲义辅助!同乡游有辅助软件吗(辅助挂)原来是真的有辅助挂(有挂技巧)1、游戏颠覆性的策略玩法,独创攻...
妙计辅助!哈局辅助作必弊(辅助... 妙计辅助!哈局辅助作必弊(辅助挂)本来存在有辅助app(有挂技巧)1)哈局辅助作必弊免费钻石:进一步...