🚀🚀🚀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;
}

效果如下

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

相关推荐
小满zs6 分钟前
Next.js第五章(动态路由)
前端
清沫10 分钟前
VSCode debugger 调试指南
前端·javascript·visual studio code
一颗宁檬不酸43 分钟前
页面布局练习
前端·html·页面布局
zhenryx2 小时前
React Native 自定义 ScrollView 滚动条:开箱即用的 IndicatorScrollView(附源码示例)
javascript·react native·react.js·typescript
金木讲编程2 小时前
Claude、Agent与Copilot协作生成Angular应用
前端·ai编程
振华OPPO3 小时前
Vue:“onMounted“ is defined but never used no-unused-vars
前端·javascript·css·vue.js·前端框架
欧雷殿3 小时前
在富阳银湖成立地域化的软件研发团队
前端·程序员·创业
李慕婉学姐3 小时前
【开题答辩过程】以《Javaweb的火花流浪动物救助系统设计与实现》为例,不会开题答辩的可以进来看看
vue.js·spring boot·mysql
狂炫冰美式4 小时前
前端实时推送 & WebSocket 面试题(2026版)
前端·http·面试
JefferyXZF4 小时前
新手建站零门槛!Vercel+Cloudflare+Namesilo域名购买部署全流程
前端