当前位置: 首页 > wzjs >正文

做分享网站seo网络营销外包

做分享网站,seo网络营销外包,有哪些品牌做打底衫的网站,网页美工设计学习📅 我们继续 50 个小项目挑战!—— Blurry Loading 组件 仓库地址:https://github.com/SunACong/50-vue-projects 项目预览地址:https://50-vue-projects.vercel.app/ ✨ 组件目标 实现一个加载进度条,随着加载进度的…

📅 我们继续 50 个小项目挑战!—— Blurry Loading 组件

  • 仓库地址:https://github.com/SunACong/50-vue-projects

  • 项目预览地址:https://50-vue-projects.vercel.app/

在这里插入图片描述


✨ 组件目标

  • 实现一个加载进度条,随着加载进度的增加,背景图像逐渐从模糊变清晰

  • 展示一个百分比数字,表示当前的加载进度

  • 整个过程无需外部库,完全依赖 Vue3 和 Tailwind CSS


🧱 技术实现点

  • Vue3 的响应式状态管理(ref)

  • 使用 onMounted 和 onBeforeUnmount 生命周期钩子管理定时器

  • Tailwind CSS 的 absolute、inset-0、bg-cover、bg-center 等布局类

  • 动态绑定内联样式,实现模糊效果的渐变

🔧 BlurryLoading.vue 组件实现

<template><div class="relative h-screen w-screen"><div:style="{ filter: `blur(${blurPx}px)` }"class="absolute inset-0 bg-[url('https://images.unsplash.com/photo-1576161787924-01bb08dad4a4?auto=format&fit=crop&w=2104&q=80')] bg-cover bg-center bg-no-repeat"></div><div class="absolute inset-0 flex items-center justify-center"><div class="text-5xl font-bold text-gray-300">{{ loading }}%</div></div></div>
</template><script setup>
import { ref, onMounted, onBeforeUnmount } from 'vue'const loading = ref(0)
const blurPx = ref(30)let intervalonMounted(() => {interval = setInterval(() => {if (loading.value < 100) {loading.value += 2blurPx.value = 30 * (1 - loading.value / 100)} else {clearInterval(interval)}}, 30)
})onBeforeUnmount(() => {clearInterval(interval)
})
</script>

⭐ 渐显效果

  • ref 变量 opacity,根据 loading.value 动态变化,随着加载进度的推进从 0 线性增长到 1
  • 配合 transition-opacity duration-500 的 Tailwind 类,使背景图从完全透明渐显到完全不透明。
  • 为任何元素设置 :style="{ opacity: xxx }" 配合 Tailwind 的过渡类,都可以实现渐显。

💡 TailwindCSS 样式重点讲解

类名功能描述
absolute inset-0使元素绝对定位并填满父容器
bg-cover背景图像覆盖整个容器
bg-[url(xxx)]设置背景图像
bg-center背景图像居中显示
bg-no-repeat背景图像不重复
text-5xl设置字体大小为 5xl
font-bold设置字体加粗
text-gray-300设置字体颜色为灰色(300)

🦌 常量定义 + 组件路由

constants/index.js 添加组件预览常量:

export const projectList = [
{id: 5,title: 'Blurry Loading',image: 'https://50projects50days.com/img/projects-img/5-blurry-loading.png',link: 'BlurryLoading',}
]

router/index.js 中添加路由选项:

{path: '/BlurryLoading',name: 'BlurryLoading',component: () => import('@/projects/BlurryLoading.vue')
}

🚀 小结

这个组件展示了如何结合 Vue3 的响应式特性和 Tailwind CSS 的实用工具类,实现一个动态的加载效果。通过动态调整背景图像的模糊程度,提升了用户体验。

📅 明日预告:Scroll Animation!实现滚动动画组件。

http://www.dtcms.com/wzjs/132628.html

相关文章:

  • 中国建设银行青海省分行网站windows优化大师有哪些功能
  • 找人做短视频网站专业做网络推广的公司
  • 达日县公司网站建设seo综合查询站长工具关键词
  • 培训型网站建设方案安徽seo优化规则
  • 设计教学网站推荐电脑培训班在哪里有最近的
  • 手机登录网站后台爱战网关键词查询网站
  • 网站 分析广州企业网站推广
  • seo推广介绍更先进的seo服务
  • 做竞争小的网站搜索引擎优化的含义
  • wordpress 设置子菜单什么是搜索引擎优化推广
  • java做网站开发小说推广关键词怎么弄
  • 大网站制作优化设计答案大全
  • 阳江人才网建站seo是什么
  • 个人网页制作成品免费开源代码百度seo关键词报价
  • 临沂医院手机网站建设谷歌推广怎么操作
  • 做网站需要掌握什么seo查询官方网站
  • 做网站一屏一屏的网站推广优化公司
  • 廊坊网站开发公司重要新闻
  • 徐州编程培训机构seo网站推广公司
  • 洛阳做网站汉狮网络百度网页pc版登录
  • 郫县专业的网站建设优化方案的格式及范文
  • 阆中 网站建设互联网产品推广是做什么的
  • 网站做多个语言有什么好处免费做网站推广的软件
  • 石家庄企业做网站经典营销案例分析
  • logo在线设计生成信阳seo推广
  • 图表统计类手机网站开发全网整合营销平台
  • 要解析做邮箱以及网站手机怎么搭建属于自己的网站
  • 创建一家网站如何创郑州seo实战培训
  • 网站建设的想法百度推广培训机构
  • 备案期间 网站sem技术培训