crip-vue-loading
v1.2.5
Published
Loading bar for Vue.js apps using axios and vue-router
Downloads
383
Readme
crip-vue-loading
A Vue.js project to wrap axios and display global loading bar of http requests. For more details read documentation with examples
Usage
Install
> npm i -S crip-vue-loading
Setup
import Vue from "vue"
import CripLoading from "crip-vue-loading"
import axios from "axios"
// Install component in to Vue instance and inject in to axios.
Vue.use(CripLoading, {axios})
Display loading bar
// App.vue
<template>
<div class="container">
<div class="row">
<div class="col-lg-6 col-lg-offset-3 col-md-8 col-md-offset-2">
<button class="btn btn-primary" @click="save($event, 2)">Save</button>
</div>
</div>
</div>
</template>
<script>
import axios from 'axios'
export default {
methods: {
async save (e, timeout = 0) {
try {
// simply call axios to save or request data and loading bar will
// show up while response is not received from server.
await axios.get(`http://www.fakeresponse.com/api/?sleep=${timeout}`)
} catch (err) {
console.error(err)
}
},
},
}
</script>
TODO:
- Add algorithm with exponential progression instead of current linear;
Build Setup
# install dependencies and serve with hot reload at localhost:8080
> npm i && npm run dev
Release steps
> npm run release