码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • vue 项目在加载完成之前,显示预置加载动画


    vue 项目在加载完成之前,显示预置加载动画

    自己有一个日记项目,由于服务器带宽很小1MB,在加载之前页面中显示是空白的,就想给它加个前置的动画,这个用户体验更好。

    一、实现

    1. 定义项目入口

    如果你是 pwa 应用, vue3 默认都已经是 pwa 应用,就需要在 vue.config.js 的 pwa 字段中确保 pwa.manifestOptions.start_url 是 index.html。
    比如我的配置如下

      /**
       * PWA 设置
       */
      pwa: {
        name: '日记', // 名字
        themeColor: "#373737", // 背景颜色
        appleMobileWebAppCapable: true, // 苹果 WebApp 支持
    
        // manifest 设置
        manifestOptions: {
          name: '标题日记',
          short_name: "日记",
          theme_color: "#373737",
          start_url: "./index.html",
          display: "standalone",
          background_color: "#373737",
          icons: [
            {
              src: "logo.svg",
              sizes: "512x512",
              type: "image/svg+xml",
              purpose: "any",
            },
            {
              src: "appicon-apple.png",
              sizes: "512x512",
              type: "image/png",
              purpose: "any",
            },
          ],
        }
      }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32

    2. 在 index.html 添加需要展示的预置动画

    这里看个人发挥了,就是把需要展示的放到 index.html 中即可,放到 id="app" 的 div 之外。
    比如我的是

    
    
    <link rel="stylesheet" href="preloading.css">
    
    <view class="preloading">
        <view class="logo-preloading">
            <img src="logo.svg" alt="LOGO">
        view>
        <view class="preloading-title">载入中view>
        <div class="loading">
            <div class="loading-1 loading-item">div>
            <div class="loading-2 loading-item">div>
            <div class="loading-3 loading-item">div>
        div>
    view>
    
    <div id="app">div>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    这样在项目还没有加载完成之前就能显示这个 .preloading 内的内容了

    3. 项目加载完成后,隐藏掉之前的预置动画内容

    这个简单,只需要在 app.vue 的 created 或 mounted 方法中隐藏这个东西即可

    app.vue

    created() {
        // 日记项目载入后,隐藏 preloading
        document.querySelector('.preloading').style.display = 'none'
    },
    
    • 1
    • 2
    • 3
    • 4

    二、最终效果

    三、开源项目

    可以从我的这个开源项目中查看源代码:
    https://github.com/KyleBing/diary

  • 相关阅读:
    微头条项目实战:新增RequestHeader注解
    计算机组成原理习题课第一章-2(唐朔飞)
    计算机毕业设计选题Java毕业设计之基于SSM实现的仓库管理系统
    Java进阶总结——集合
    Latex 通过\item控制编号
    Acwing 2944. 回家的路
    【深度学习】 Python 和 NumPy 系列教程(十):NumPy详解:2、数组操作(索引和切片、形状操作、转置操作、拼接操作)
    入职阿里必会199道SpringCloud面试题,你能掌握多少?
    jenkins+junit4+allure+selenium实现自动化测试与结果可视化
    c#学习系列相关之多线程(三)----invoke和begininvoke
  • 原文地址:https://blog.csdn.net/KimBing/article/details/127933370
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号