search
HomeWeb Front-endVue.jsHow to handle page skeleton and loading animation in Vue
How to handle page skeleton and loading animation in VueOct 15, 2023 pm 01:04 PM
loading animationProcessing in vuePage skeleton

How to handle page skeleton and loading animation in Vue

How to handle page skeleton and loading animation in Vue

In modern web applications, users have high expectations for a fast loading page experience. In order to meet this demand, developers can use some technical means to improve the loading speed of the page, and add some animation effects to enhance the user experience.

Vue, as a popular JavaScript framework, provides many options for handling page skeletons and loading animations. Some common methods will be introduced in detail below and specific code examples will be given.

1. Page skeleton

The page skeleton refers to displaying some basic layouts and styles during the page loading process, so that users can perceive that the page is loading and reserve space for upcoming content. . This prevents the page from going blank during loading and improves user experience.

In Vue, you can use Vue's render function to create the page skeleton. Here is an example:

Vue.component('skeleton', {
  render: function (createElement) {
    return createElement('div', {
      attrs: {
        class: 'skeleton'
      }
    }, [
      createElement('div', {
        attrs: {
          class: 'skeleton-header'
        }
      }),
      createElement('div', {
        attrs: {
          class: 'skeleton-content'
        }
      }),
      createElement('div', {
        attrs: {
          class: 'skeleton-footer'
        }
      })
    ])
  }
})

In the above code, we create a global Vue component named "skeleton", which uses a rendering function to generate the HTML structure of the page skeleton. In this example, we create a skeleton containing a header, content, and footer and style it using CSS class names.

Then, in the component that needs to display the page skeleton, conditional rendering can be used to determine when to display the page skeleton. Here is an example:

<template>
  <div>
    <div v-if="loading">
      <skeleton></skeleton>
    </div>
    <div v-else>
      <!-- 页面内容 -->
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      loading: true
    }
  },
  mounted() {
    // 模拟异步数据加载
    setTimeout(() => {
      this.loading = false
    }, 2000)
  }
}
</script>

In the above example, we use Vue’s conditional rendering instruction v-if to determine when to display the page skeleton. When loading is true, the skeleton page is displayed; when loading is false, the real page content is displayed. In the mounted lifecycle hook, we simulate the process of asynchronous data loading and set the value of loading to false after 2 seconds, as shown in the example.

Through the above method, we can realize the skeleton display during the page loading process and enhance the user experience.

2. Loading animation

The loading animation is to convey the information that the page is loading to the user and provide a kind of visual feedback. In Vue, loading animation can be achieved through CSS animation, third-party libraries or Vue's transition effects.

  1. CSS Animation

Using CSS animation is one of the simplest and most common ways. For example, we can define a rotation animation:

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.loading {
  animation: spin 1s infinite linear;
}

Then, add the CSS class name to the element that needs to display the loading animation, as follows:

<template>
  <div>
    <div v-if="loading" class="loading"></div>
    <div v-else>
      <!-- 页面内容 -->
    </div>
  </div>
</template>

In the above example, when loading is When true, displays an element with the "loading" class name, which will trigger a CSS animation.

  1. Third-party libraries

In addition to using CSS animations, we can also use some third-party libraries to achieve more complex loading animation effects. For example, use the "vue-spinner" library to display a loading animation of a rotating icon:

First, install the "vue-spinner" library:

npm install vue-spinner --save

Then, when you need to use the loading animation component Import and use this library in:

<template>
  <div>
    <div v-if="loading">
      <spinner></spinner>
    </div>
    <div v-else>
      <!-- 页面内容 -->
    </div>
  </div>
</template>

<script>
import Spinner from 'vue-spinner'

export default {
  components: {
    Spinner
  },
  data() {
    return {
      loading: true
    }
  },
  mounted() {
    // 模拟异步数据加载
    setTimeout(() => {
      this.loading = false
    }, 2000)
  }
}
</script>

In the above example, we use conditional rendering to determine when to display the loading animation in the component that needs to display the loading animation. When loading is true, display a "spinner" component, which will display a rotating loading icon. When loading is false, the real page content is displayed.

To sum up, Vue provides a variety of methods for processing page skeletons and loading animations. By using rendering functions and conditional rendering, we can display the page skeleton; and using CSS animation and third-party libraries, we can achieve various cool loading animation effects. By using these technical means, we can improve the page loading speed of web applications and provide users with a better experience.

The above is the detailed content of How to handle page skeleton and loading animation in Vue. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
How to configure the lifecycle hooks of the component in VueHow to configure the lifecycle hooks of the component in VueMar 04, 2025 pm 03:29 PM

This article clarifies the role of export default in Vue.js components, emphasizing that it's solely for exporting, not configuring lifecycle hooks. Lifecycle hooks are defined as methods within the component's options object, their functionality un

How to configure the watch of the component in Vue export defaultHow to configure the watch of the component in Vue export defaultMar 04, 2025 pm 03:30 PM

This article clarifies Vue.js component watch functionality when using export default. It emphasizes efficient watch usage through property-specific watching, judicious deep and immediate option use, and optimized handler functions. Best practices

What is Vuex and how do I use it for state management in Vue applications?What is Vuex and how do I use it for state management in Vue applications?Mar 11, 2025 pm 07:23 PM

This article explains Vuex, a state management library for Vue.js. It details core concepts (state, getters, mutations, actions) and demonstrates usage, emphasizing its benefits for larger projects over simpler alternatives. Debugging and structuri

How do I create and use custom plugins in Vue.js?How do I create and use custom plugins in Vue.js?Mar 14, 2025 pm 07:07 PM

Article discusses creating and using custom Vue.js plugins, including development, integration, and maintenance best practices.

How do I implement advanced routing techniques with Vue Router (dynamic routes, nested routes, route guards)?How do I implement advanced routing techniques with Vue Router (dynamic routes, nested routes, route guards)?Mar 11, 2025 pm 07:22 PM

This article explores advanced Vue Router techniques. It covers dynamic routing (using parameters), nested routes for hierarchical navigation, and route guards for controlling access and data fetching. Best practices for managing complex route conf

What are the key features of Vue.js (Component-Based Architecture, Virtual DOM, Reactive Data Binding)?What are the key features of Vue.js (Component-Based Architecture, Virtual DOM, Reactive Data Binding)?Mar 14, 2025 pm 07:05 PM

Vue.js enhances web development with its Component-Based Architecture, Virtual DOM for performance, and Reactive Data Binding for real-time UI updates.

How do I configure Vue CLI to use different build targets (development, production)?How do I configure Vue CLI to use different build targets (development, production)?Mar 18, 2025 pm 12:34 PM

The article explains how to configure Vue CLI for different build targets, switch environments, optimize production builds, and ensure source maps in development for debugging.

How do I use Vue with Docker for containerized deployment?How do I use Vue with Docker for containerized deployment?Mar 14, 2025 pm 07:00 PM

The article discusses using Vue with Docker for deployment, focusing on setup, optimization, management, and performance monitoring of Vue applications in containers.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),