🚀🚀🚀Vue3优雅加载图片的一些动画Ⅱ

文章同步在公众号:萌萌哒草头将军,欢迎关注

这篇文章是紧接上篇的内容,Vue3如何优雅的加载大量图片🚀🚀🚀

上篇文章,我们只是简单增加了一个渐变的效果。

这篇文章,我分享两个新的动画:

🚀 高斯模糊效果

js 复制代码
function callback(
  entries: IntersectionObserverEntry[],
  observer: IntersectionObserver
) {
  entries.forEach((entry) => {
    if (entry.intersectionRatio <= 0) return;
    const img = entry.target as HTMLImageElement;
    const src = img.getAttribute("data-src");

    img.setAttribute("src", src ?? ""); // 将真实的图片地址赋给 src 属性

    img.onload = () => {
      img.setAttribute("class", "fade-in");
    };

    observer.unobserve(img);
  });
}

对应的样式

css 复制代码
@keyframes fadeIn {
  from {
    filter: blur(10px);
  }
  to {
    filter: blur(0px);
  }
}

.fade-in {
  animation: fadeIn 0.3s ease-in;
}

效果如下:

🚀 缩放动画

js 复制代码
img.onload = () => {
  img.setAttribute("class", "transform-in");
};

对应的样式

css 复制代码
@keyframes bounce-in {
  0% {
    transform: scale(0.8);
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}
.transform-in {
  opacity: 0;
  animation: bounce-in 0.5s ease-in-out forwards;
}

效果如下

希望这两个新的动画对你有帮助。

相关推荐
allen_19981 分钟前
掘金的广告越来越烦人了,悄悄把它隐藏起来🤫
前端·css·掘金社区
Linux运维老纪2 分钟前
Linux系统常见磁盘扩容操作(Common Disk Expansion Operations in Linux Systems)
linux·运维·服务器·前端·数据库·云计算·运维开发
一天睡25小时2 分钟前
JavaScript 核心:数组/字符串 API 精要指南
前端·javascript
I like Code?11 分钟前
AntVG2可视化学习与开发笔记-React19(持续更新)
javascript·笔记·学习
山野春茶13 分钟前
js基础回顾 replace 和 正则
前端
gnip14 分钟前
低代码撤销回退功能实现
前端
拖孩16 分钟前
【Nova UI】七、SASS 全局变量体系:组件库样式开发的坚固基石
前端·javascript·vue.js
胚芽鞘68119 分钟前
添加登录和注册功能
javascript·vue.js·elementui
pe7er31 分钟前
枚举管理的最佳实践:枚举 + 数据源 + Map 的统一编码风格
javascript
神毓逍遥kang34 分钟前
Drizzle-Orm + mysql + Nest 快速构建crud 体验下一代orm魅力
前端·后端