返回顶部
首页 > 资讯 > 精选 >vue前端页面数据加载怎么添加loading效果
  • 538
分享到

vue前端页面数据加载怎么添加loading效果

2023-07-02 14:07:50 538人浏览 安东尼
摘要

这篇文章主要介绍了Vue前端页面数据加载怎么添加loading效果的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue前端页面数据加载怎么添加loading效果文章都会有所收获,下面我们一起来看看吧。前端页面数

这篇文章主要介绍了Vue前端页面数据加载怎么添加loading效果的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue前端页面数据加载怎么添加loading效果文章都会有所收获,下面我们一起来看看吧。

前端页面数据加载添加loading效果

vue前端页面数据加载怎么添加loading效果

具体实现

let thisContent = this;let loading = thisContent.$loading({        lock: true,        text: '上传中,请稍候...',        spinner: 'el-icon-loading',        background: 'rgba(0, 0, 0, 0.5)'      })// 中间进行一系列的操作// 上传成功后关闭loading, 并显示上传成功loading.close();thisC.$message('上传文件成功');

这样一个简单的loading效果就实现了。

全局loading配置

请求的时候 需要一个全局loading来拦截 若是页面单独引用的话 就有点繁琐了 所以需要再全局封装一个 此时就要明白 再哪里封装了 先考虑一下 为什么要用

一方面是为了防止重复操作

另一方面是为了一个加载的效果能够更明显 

所以 再请求的时候加 就能联想到axiOS拦截器的位置处理了 话不多说 开始撸代码 全程copy就行了  

1 再src/componennts/Spinner下面建立一个index.vue

<template>  <div class="loading-page bg-opacity" :>    <div class="dark" @dblclick="close">      <div class="la-ball-spin-clockwise la-2x">        <div></div>        <div></div>        <div></div>        <div></div>        <div></div>        <div></div>        <div></div>        <div></div>      </div>    </div>  </div></template>
<script>  export default {    data() {      return {        hide: true      }    },    methods: {      close() {        document.querySelector('.loading-page').style.display = 'none';      }    }  }</script>
 <!-- Add "scoped" attribute to limit CSS to this component only --><style scoped lang="scss">  .show {    display: block;  }   .hide {    display: none;  }   .loading-page {    background: rgba(0, 0, 0, .65);    display: none;    position: fixed;    top: 0;    left: 0;    right: 0;    bottom: 0;    min-height: 100%;    min-width: 100%;    transition: all 1s;    z-index: 20000;    &.hide {      display: none;    }    &.bg-opacity {      background: rgba(0, 0, 0, 0);    }    .dark {      width: 100px;      height: 100px;      border-radius: 10px;      background: rgba(0, 0, 0, .65);      position: absolute;      top: 40%;      left: 50%;      margin-left: -50px;      text-align: center;      img {        width: 70px;        height: 70px;        margin-top: 15px;      }    }  }  .la-ball-spin-clockwise{    width: 64px;    height: 64px;    margin-top: 18px;    margin-left: 18px;    display: block;    font-size: 0;    color: #fff;    position: relative;    box-sizing: border-box;    animation-play-state: running;  }  .la-ball-spin-clockwise>div{    width: 16px;    height: 16px;    margin-top: -8px;    margin-left: -8px;    position: absolute;    border-radius: 100%;    animation: ball-spin-clockwise 1s infinite ease-in-out;    display: inline-block;    float: none;    background-color: currentColor;    border: 0 solid currentColor;    animation-play-state: running;  }  .la-ball-spin-clockwise>div:nth-child(1){    top: 5%;    left: 50%;    WEBkit-animation-delay: -.875s;    -moz-animation-delay: -.875s;    -o-animation-delay: -.875s;    animation-delay: -.875s;  }  .la-ball-spin-clockwise>div:nth-child(2) {    top: 18.1801948466%;    left: 81.8198051534%;    -webkit-animation-delay: -.75s;    -moz-animation-delay: -.75s;    -o-animation-delay: -.75s;    animation-delay: -.75s;  }  .la-ball-spin-clockwise>div:nth-child(3) {    top: 50%;    left: 95%;    -webkit-animation-delay: -.625s;    -moz-animation-delay: -.625s;    -o-animation-delay: -.625s;    animation-delay: -.625s;  }  .la-ball-spin-clockwise>div:nth-child(4) {    top: 81.8198051534%;    left: 81.8198051534%;    -webkit-animation-delay: -.5s;    -moz-animation-delay: -.5s;    -o-animation-delay: -.5s;    animation-delay: -.5s;  }  .la-ball-spin-clockwise>div:nth-child(5) {    top: 94.9999999966%;    left: 50.0000000005%;    -webkit-animation-delay: -.375s;    -moz-animation-delay: -.375s;    -o-animation-delay: -.375s;    animation-delay: -.375s;  }  .la-ball-spin-clockwise>div:nth-child(6) {    top: 81.8198046966%;    left: 18.1801949248%;    -webkit-animation-delay: -.25s;    -moz-animation-delay: -.25s;    -o-animation-delay: -.25s;    animation-delay: -.25s;  }  .la-ball-spin-clockwise>div:nth-child(7) {    top: 49.9999750815%;    left: 5.0000051215%;    -webkit-animation-delay: -.125s;    -moz-animation-delay: -.125s;    -o-animation-delay: -.125s;    animation-delay: -.125s;  }  .la-ball-spin-clockwise>div:nth-child(8) {    top: 18.179464974%;    left: 18.1803700518%;    -webkit-animation-delay: 0s;    -moz-animation-delay: 0s;    -o-animation-delay: 0s;    animation-delay: 0s;  }  @-webkit-keyframes ball-spin-clockwise{    0%,100%{      opacity:1;      -webkit-transfORM:scale(1);      transform:scale(1)}    20%{      opacity:1    }    80%{      opacity:0;      -webkit-transform:scale(0);      transform:scale(0)    }  }  @-moz-keyframes ball-spin-clockwise{    0%,100%{      opacity:1;      -moz-transform:scale(1);      transform:scale(1)    }    20%{      opacity:1    }    80%{      opacity:0;      -moz-transform:scale(0);      transform:scale(0)    }  }  @-o-keyframes ball-spin-clockwise{    0%,100%{      opacity:1;      -o-transform:scale(1);      transform:scale(1)    }    20%{      opacity:1    }    80%{      opacity:0;      -o-transform:scale(0);      transform:scale(0)    }  }  @keyframes ball-spin-clockwise{    0%,100%{      opacity:1;      -webkit-transform:scale(1);      -moz-transform:scale(1);      -o-transform:scale(1);      transform:scale(1)    }    20%{      opacity:1    }    80%{      opacity:0;      -webkit-transform:scale(0);      -moz-transform:scale(0);      -o-transform:scale(0);transform:scale(0)    }  }</style>

2 再utils下面tools.js

class Msg {  static loading() {    document.querySelector('.loading-page').style.display = 'block';  }   static hideLoading() {    document.querySelector('.loading-page').style.display = 'none';  }} export {  Tools,  Msg}

3 再utils下面建议一个request.js 封装的axios请求

import axios from 'axios'import qs from 'qs'import { MessageBox, Message } from 'element-ui'import store from '@/store'import { getToken } from '@/utils/auth'import router from '@/router'import {Msg} from '@/utils/tools';import { removeToken } from '@/utils/auth' var allResquest = 0;// create an axios instanceconst service = axios.create({    baseURL: process.env.VUE_APP_BASE_api, // api 的 base_url    withCredentials: true, // 跨域请求时发送 cookies    paramsSerializer: params => { // 查询字符串中的数组不使用方括号return qs.stringify(params, { indices: false })},    timeout: 15000 // request timeout}) // request interceptorservice.interceptors.request.use(    config => {      if (store.getters.token) {            config.headers['Authorization'] = 'Bearer ' + getToken()            config.headers['filterMode'] = localStorage.getItem('dataType')        }      config.headers['project'] = "csr"      allResquest = allResquest + 1;      if (config.mask !== true)  {        Msg.loading()      }      return config    },    error => {        return Promise.reject(error)    }) // response interceptorservice.interceptors.response.use(            response => {        allResquest = allResquest - 1;        const res = response.data;        if (response.status === 200) {          if (allResquest === 0) {            Msg.hideLoading();          }            // 50008 系统无此账号            // 50010 账号禁用            // 50012 账号或密码错误            // 50013 主账号被禁用,禁止登录            // 50014 token失效            // 50015 登录失败,无操作权限,请联系系统管理员!            // 50016 验证码错误            // 429   限流 服务器拥挤,请稍后再试            // -999  未知错误            // 403  无权限            if (res.code === 50008 || res.code === 50010 || res.code === 50012 || res.code === 50013 ||              res.code === 50016 || res.code === 50015 || res.code === 429 || res.code === -999 || res.code === 403 || res.code === 500) {                Message({                    message: res.msg || 'error',                    type: 'error',                    duration: 5 * 1000,                    offset: 0                })              return Promise.reject(res.msg || 'error')            } else if (res.code === 50014) {              if (store.getters.token) {                removeToken()              }              MessageBox.alert( res.msg,'错误提示', {                confirmButtonText: '确定',                callback: action => {                  store.dispatch('loGout')                  router.push(`/login`)                }              })              return false            }            return res        }    },    error => {        allResquest = allResquest - 1;        Msg.hideLoading();        Message({            message: '服务拥挤,请稍后重试!',            type: 'error',            duration: 5 * 1000        })        return Promise.reject(error)    })export default service

4 修改app.vue

<template>  <div id="app">    <router-view />    <Spinner></Spinner>  </div></template>
<script>import Spinner from '@/components/Spinner'export default {  name: 'App',  components: {    Spinner  }}</script>
<style></style>

关于“vue前端页面数据加载怎么添加loading效果”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“vue前端页面数据加载怎么添加loading效果”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网精选频道。

--结束END--

本文标题: vue前端页面数据加载怎么添加loading效果

本文链接: https://lsjlt.com/news/342487.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • vue前端页面数据加载怎么添加loading效果
    这篇文章主要介绍了vue前端页面数据加载怎么添加loading效果的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue前端页面数据加载怎么添加loading效果文章都会有所收获,下面我们一起来看看吧。前端页面数...
    99+
    2023-07-02
  • vue前端页面数据加载添加loading效果的实现
    目录前端页面数据加载添加loading效果具体实现全局loading配置1 再src/componennts/Spinner下面建立一个index.vue2 再utils下面tool...
    99+
    2024-04-02
  • Vue实现网页首屏加载动画及页面内请求数据加载loading效果
    目录简介:使用范例:1、四圆点加载动画2、旋涡加载动画3、电池状态加载动画4、请求数据缓慢实现loading提示【推荐】Ⅰ、封装loading组件【推荐】Ⅱ、通过elementUI实...
    99+
    2023-02-10
    vue 加载动画 vue 页面加载动画 vue 页面加载
  • 怎么用纯CSS3实现页面loading加载动画效果
    小编给大家分享一下怎么用纯CSS3实现页面loading加载动画效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!  ...
    99+
    2024-04-02
  • vue实现页面添加水印效果
    最近在做项目的时候要求给页面加上水印效果,废话不多说直接上代码: export function watermark(settings) { debugger; //默认...
    99+
    2024-04-02
  • 怎么运用layui数据添加页面的前端布局
    这篇文章主要介绍怎么运用layui数据添加页面的前端布局,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!layui数据添加页面的前端布局1、在首页面增加一个学生信息添加,代码如下:<title>学生信息添加...
    99+
    2023-06-15
  • vue项目页面的打印和下载PDF加loading效果的实现(加水印)
    目录vue页面的打印和下载PDF(加水印)vue项目页面的打印vue项目页面下载PDF封装异步PDF下载函数并添加loading效果总结vue页面的打印和下载PDF(加水印) vue...
    99+
    2022-12-08
    vue页面的打印 vue页面的下载 下载PDF加loading效果
  • CSS3怎么实现页面加载效果
    这篇文章给大家分享的是有关CSS3怎么实现页面加载效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。知识点讲解   (1)animation:设置动画属性   animati...
    99+
    2024-04-02
  • 怎么用css3实现loading加载动画效果
    这篇文章主要介绍“怎么用css3实现loading加载动画效果”,在日常操作中,相信很多人在怎么用css3实现loading加载动画效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大...
    99+
    2024-04-02
  • vue怎么添加数组页面及时显示
    今天小编给大家分享一下vue怎么添加数组页面及时显示的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。如何添加数组页面及时显示最...
    99+
    2023-06-30
  • VUE页面中怎么加载外部HTML
    这篇文章主要介绍“VUE页面中怎么加载外部HTML”,在日常操作中,相信很多人在VUE页面中怎么加载外部HTML问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”VUE页面中怎么...
    99+
    2024-04-02
  • vue+ElementUI如何实现订单页动态添加产品数据效果
    这篇文章主要为大家展示了“vue+ElementUI如何实现订单页动态添加产品数据效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue+ElementUI如...
    99+
    2024-04-02
  • Ajax加载外部页面弹出层效果怎么实现
    这篇文章主要介绍“Ajax加载外部页面弹出层效果怎么实现”,在日常操作中,相信很多人在Ajax加载外部页面弹出层效果怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Aj...
    99+
    2024-04-02
  • 前端怎么做数据加密
    在前端中使用aes加密算法对数据进行加密的方法前端代码如下:function aesEncrypt(text, key) {const textBytes = aesjs.utils.utf8.toBytes(text); // 把字符串转...
    99+
    2024-04-02
  • vue-router懒加载下载js的过程中添加loading提示避免无响应怎么解决
    今天小编给大家分享一下vue-router懒加载下载js的过程中添加loading提示避免无响应怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,...
    99+
    2023-07-04
  • 怎么用Vue+OpenLayer为地图添加风场效果
    这篇“怎么用Vue+OpenLayer为地图添加风场效果”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么用Vue+Open...
    99+
    2023-06-30
  • 怎么为Vue路由添加淡入淡出效果
    今天小编给大家分享一下怎么为Vue路由添加淡入淡出效果的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Vue路由基础在开始之前...
    99+
    2023-07-06
  • 为vue-router懒加载时下载js的过程中添加loading提示避免无响应怎么办
    这篇文章给大家分享的是有关为vue-router懒加载时下载js的过程中添加loading提示避免无响应怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。用过vue-route...
    99+
    2024-04-02
  • vue怎么加载本地json数据
    本篇内容主要讲解“vue怎么加载本地json数据”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue怎么加载本地json数据”吧!vue加载本地json数据json数据存放在除static静态文...
    99+
    2023-06-29
  • 微信小程序如何实现页面滑动屏幕加载数据效果
    小编给大家分享一下微信小程序如何实现页面滑动屏幕加载数据效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!我们先看看效果图:创建...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作