需求来源:当使用React时,使用 umi loading 很方便,页面对http请求发生改变时,也会自动改变loading的相关状态(true/false)

对VUE插件进行找寻,发现没找到合适内容,就参考思路自行设计了一套

功能实现

界面Loading自动加载,不需要在每个请求前后进行拦截,且配置简单、实现方便,如图:

技术栈

vue、vuex、axios(http请求)


开始实现

第一步,文件目录结构介绍:

  lib/http: Http封装,对系统请求进行封装

  service/api.js: 请求接口提取(统一管理请求URL,详细内容见右)

  store.js: 全局状态

第二步,接口统一提取(service/api.js)

  如上是提取的统一URL内容,使用时直接引入

第三步,全局状态封装(store.js)

 import Vue from "vue";
import Vuex from "vuex";
import * as Service from '@/service/api'; Vue.use(Vuex); // 实现自动注册loading URl
const loading = {};
Object.values(Service.URLS).forEach(value => {
loading[value] = false;
}); export default new Vuex.Store({
state: {
// url请求列表,自动注册
loading: loading
},
mutations: {
loading(state, url) {
state.loading[url] = true;
},
unloading(state, url) {
state.loading[url] = false;
}
},
actions: {}
});

第四步,Http封装

 import axios from 'axios';
import store from '../../store' /**
* 设置请求前缀(末尾必须包含 / 否则会导致动态loading失败)
*/
axios.defaults.baseURL = "http://www.huic.top/"; /**
* 定义一个请求拦截器(Loading设置true)
*/
axios.interceptors.request.use(function (config) {
store.commit("loading", config.url);
return config
});
/**
* 定义一个响应拦截器(Loading设置为false)
*/
axios.interceptors.response.use(function (response) {
store.commit("unloading", response.config.url.replace(axios.defaults.baseURL, ""));
return response
});

这里的封装只封装了拦截器,并未对具体请求进行封装,因为请求封装在这里可有可无,如需要的请留一下邮箱

第五步,使用

 <script>
import './index.less';
import * as Service from '@/service/api'; export default {
data: () => ({
// 题目标签
tags: [],
}),
computed: {
tagLoading() {
return this.$store.state.loading[Service.URLS.ARTICLE_TAG_LEVEL];
},
testLoading() {
return this.$store.state.loading[Service.URLS.ARTICLE_TEST];
}
},
created() {
this.queryTags();
},
components: {
},
methods: {
/**
* 查询标签列表(请求封装查询,也可直接使用 axios.post 等内容)
*/
queryTags() {
Service.articleTagLevel({}).then(res => {
if (res.isOk()) {
this.tags = res.data.records;
}
});
}
}
};
</script>

以上代码为VUE简单使用,则将loading - url - 组件进行绑定,则代表在本页面进行请求,例如:articleTagLevel,则会自动绑定loading(见12行)

以上核心代码为10-17行,代表将url和loading属性绑定,使用方法见下:

 <div class="test-body-item">
<Row>
<Col span="2" class="test-body-item-title">
标签选择
</Col>
<Col span="21" offset="1">
<TagGroup :data="tags" :loading="tagLoading"/>
</Col>
</Row>
</div>

使用方法:第 7 行,其中 :loading="tagLoading" 则代表将tagLoading属性绑定到loading参数中

至此,实现成功.

End.

VUE动态(自动)Loading【绑定到URL】,同页面多个Loading互不冲突的更多相关文章

  1. Vue动态添加v-model绑定及获取其返回数据

    从数据库拿到的动态数据绑定到页面对应的v-model或者v-bind上,并且根据对页的操作获取到返回的值: 1.首先在data里定义一个数据 timeTip 为一个空数组 data () { retu ...

  2. Vue动态加载异步组件

    背景: 目前我们项目都是按组件划分的,然后各个组件之间封装成产品.目前都是采用iframe直接嵌套页面.项目中我们还是会碰到一些通用的组件跟业务之间有通信,这种情况下iframe并不是最好的选择,if ...

  3. 【前端】vue.js实现输入框绑定

    vue.js实现输入框绑定 实现效果如下: 实现代码及注释 <!DOCTYPE html> <html> <head> <title>vue.js数据动 ...

  4. vue实现ajax滚动下拉加载,同时具有loading效果

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  5. Vue动态组件

    前面的话 让多个组件使用同一个挂载点,并动态切换,这就是动态组件.本文将详细介绍Vue动态组件 概述 通过使用保留的 <component> 元素,动态地绑定到它的 is 特性,可以实现动 ...

  6. Vue 框架-05-动态绑定 css 样式

    Vue 框架-05-动态绑定 css 样式 今天的小实例是关于 Vue 框架动态绑定 css 样式,这也是非常常用的一个部分 首先说一下 动态绑定,相对的大家都知道静态绑定,静态绑定的话,直接加 cl ...

  7. vue动态子组件的实现方式

    让多个组件使用同一个挂载点,并动态切换,这就是动态组件. 通过使用保留的 <component>元素,动态地绑定到它的 is 特性,可以实现动态组件. 方式一:局部注册所需组件 <d ...

  8. ZUI(BootStrap)使用vue动态插入HTMl所创建的data-toggle事件初始化方法

    用ZUI的图片浏览:lightbox 写静态html的时候是有预览效果的,使用了vue动态加载就没有效果了, 网上的说法是动态生成的没有激活事件:ZUI(BootStrap)动态插入HTMl所创建的d ...

  9. Vue的数据双向绑定和Object.defineProperty()

    Vue是前端三大框架之一,也被很多人指责抄袭,说他的两个核心功能,一个数据双向绑定,一个组件化分别抄袭angular的数据双向绑定和react的组件化思想,咱们今天就不谈这种大是大非,当然我也没到达那 ...

随机推荐

  1. git + gerrit push 代码问题

    关于refs/for 和 refs/heads: 1.     这个不是git的规则,而是gerrit的规则, 2.     Branches, remote-tracking branches, a ...

  2. C# winform 主界面打开并关闭登录界面

    在winform 界面编程中,我们有时候要在主界面打开之前先显示登录界面,当登录界面用户信息校验正确后才打开主界面,而这时登陆界面也完成使命该功成身退了. 目前有两种方法可实现: 方法1. 隐藏登录界 ...

  3. 基于SAP HANA平台的多团队产品研发

    工欲善其事必先利其器.要提高多团队的开发效率,而且还是在SAP HANA平台上,建议大家还是本着“慢就是快”的原则,不要急功近利,在没有准备好团队开发的架构时就匆忙开始功能的开发.匆忙功能开发就算了, ...

  4. Cloudera Impala需求

    Cloudera Impala需求 为了达到预期的效果,Impala依赖于软件.硬件的可用性,以及下面章节描述的配置. 继续阅读: 支持的操作系统 支持的Hadoop发布 Hive Metastore ...

  5. kafka笔记4(2)

    提交和偏移量 每次调用poll 方法,总是返回生产者写入Kafka但还没有被消费者读取过的记录我们因此可以追踪到哪些记录时被群组里的哪个消费者读取过的. 我们把更新分区当前位置的操作叫做提交. 那么消 ...

  6. 使用豆瓣的pip源安装python模块

    1.指定豆瓣pip源安装Django pip install -i https://pypi.doubanio.com/simple/ --trusted-host pypi.doubanio.com ...

  7. Tido c++线段树知识讲解(转载)

    线段树知识讲解 定义.建树.单点修改.区间查询         特别声明:如上的讲解说的是区间最大值 如果想要查询区间和 只需要改变一下建树和查询的代码就行了,如下 其他根据自己的需要进行修改即可

  8. win2008环境mysql主从配置

    一.主库相关配置.设置 step1:主库配置文件 [mysqld] # 数据库id,唯一 server-id = 1# 二进制日志文件,必填项,否则不能同步数据;如果不取名字的话,会以计算机的名字加编 ...

  9. 曹工说Tomcat1:从XML解析说起

    一.前言 第一次被人喊曹工,我相当诧异,那是有点久的事情了,楼主13年校招进华为,14年在东莞出差,给东莞移动的通信设备进行版本更新.他们那边的一个小伙子来接我的时候,这么叫我的,刚听到的时候,心里一 ...

  10. openstack namespace 的应用

    查看虚拟机网络连通性 1.neutron port-list | grep IP 2.neutron port-show ID 查看subnet 3.neutron subnet-show ID 查看 ...