Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/imcvampire/vue-axios
A small wrapper for integrating axios to Vuejs
https://github.com/imcvampire/vue-axios
axios hacktoberfest integrating-axios vue-axios vuejs wrapper
Last synced: 5 days ago
JSON representation
A small wrapper for integrating axios to Vuejs
- Host: GitHub
- URL: https://github.com/imcvampire/vue-axios
- Owner: imcvampire
- License: mit
- Created: 2016-10-25T07:39:39.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2024-06-18T15:37:24.000Z (7 months ago)
- Last Synced: 2024-10-29T15:07:23.150Z (2 months ago)
- Topics: axios, hacktoberfest, integrating-axios, vue-axios, vuejs, wrapper
- Language: JavaScript
- Homepage: https://www.npmjs.com/package/vue-axios
- Size: 3.2 MB
- Stars: 2,014
- Watchers: 44
- Forks: 183
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-github-vue - vue-axios - 将axios整合到VueJS的封装 (实用库)
- awesome-vue - vue-axios - 将axios整合到VueJS的封装 (实用库)
- awesome-github-vue - vue-axios - 将axios整合到VueJS的封装 (实用库)
- awesome - vue-axios - 将axios整合到VueJS的封装 (实用库)
- awesome-vue - vue-axios - axios?style=social) - 将axios整合到VueJS的封装 (实用库)
README
# vue-axios
[![npm version](https://img.shields.io/npm/v/vue-axios.svg?style=flat-square)](https://www.npmjs.org/package/vue-axios)
[![install size](https://packagephobia.now.sh/badge?p=vue-axios)](https://packagephobia.now.sh/result?p=vue-axios)
[![npm downloads](https://img.shields.io/npm/dm/vue-axios.svg?style=flat-square)](http://npm-stat.com/charts.html?package=vue-axios)
[![jsdelivr](https://data.jsdelivr.com/v1/package/npm/vue-axios/badge?style=rounded)](https://www.jsdelivr.com/package/npm/vue-axios)
[![License](https://img.shields.io/npm/l/vue-axios.svg)](https://www.npmjs.com/package/vue-axios)A small wrapper for integrating axios to Vuejs
## Why
I created this library because, in the past, I needed a simple solution to migrate from `vue-resource` to `axios`.
It only binds axios to the `vue` instance so you don't have to import everytime you use `axios`.
## How to install:
### ES6 Module:
```bash
npm install --save axios vue-axios
```
Import libraries in entry file:
```js
// import Vue from 'vue' // in Vue 2
import * as Vue from 'vue' // in Vue 3
import axios from 'axios'
import VueAxios from 'vue-axios'
```Usage in Vue 2:
```js
Vue.use(VueAxios, axios)
```Usage in Vue 3:
```js
const app = Vue.createApp(...)
app.use(VueAxios, axios)
```### Script:
Just add 3 scripts in order: `vue`, `axios` and `vue-axios` to your `document`.## Usage:
### in Vue 2
This wrapper bind `axios` to `Vue` or `this` if you're using single file component.
You can use `axios` like this:
```js
Vue.axios.get(api).then((response) => {
console.log(response.data)
})this.axios.get(api).then((response) => {
console.log(response.data)
})this.$http.get(api).then((response) => {
console.log(response.data)
})
```### in Vue 3
This wrapper bind `axios` to `app` instance or `this` if you're using single file component.
in option API, you can use `axios` like this:
```js
// App.vue
export default {
name: 'App',
methods: {
getList() {
this.axios.get(api).then((response) => {
console.log(response.data)
})
// or
this.$http.get(api).then((response) => {
console.log(response.data)
})
}
}
}
```however, in composition API `setup` we can't use `this`, you should use `provide` API to share the globally instance properties first, then use `inject` API to inject `axios` to `setup`:
```ts
// main.ts
import { createApp } from 'vue'
import App from './App.vue'
import store from './store'
import axios from 'axios'
import VueAxios from 'vue-axios'const app = createApp(App).use(store)
app.use(VueAxios, axios)
app.provide('axios', app.config.globalProperties.axios) // provide 'axios'
app.mount('#app')// App.vue
import { inject } from 'vue'export default {
name: 'Comp',
setup() {
const axios: any = inject('axios') // inject axiosconst getList = (): void => {
axios
.get(api)
.then((response: { data: any }) => {
console.log(response.data)
});
};return { getList }
}
}
```Please kindly check full documentation of [axios](https://github.com/axios/axios) too
## Multiple axios instances support
The library allows to have different version of axios at the same time as well as change the default registration names (e.g. `axios` and `$http`). To use this feature you need to provide options like an object where:
- `` is registration name
- `` is instance of axiosFor Vue it looks like this:
```js
// Vue 2 / Vue 3 + Composition API
import App from './App.vue'
import VueAxios from 'vue-axios'
import axios from 'axios'
import axios2 from 'axios'
Vue.use(VueAxios, { $myHttp: axios, axios2: axios2 }) // or app.use() for Vue 3 Optiona API// usage
export default {
methods: {
getList(){
this.$myHttp.get(api).then((response) => {
console.log(response.data)
})
this.axios2.get(api).then((response) => {
console.log(response.data)
})
}
}
}
```
It works similarly in Options API of Vue 3 but if you want to use Composition API you should adjust your code a bit to extract proper keys, e.g.:
```ts
// Vue 2 + Setup function
import { createApp } from 'vue'
import App from './App.vue'
import store from './store'
import axios from 'axios'
import VueAxios from 'vue-axios'const app = createApp(App).use(store)
app.use(VueAxios, { $myHttp: axios, axios2: axios2 })
app.provide('$myHttp', app.config.globalProperties.$myHttp) // provide '$myHttp'
app.provide('axios2', app.config.globalProperties.axios2) // provide 'axios2'
app.mount('#app')// App.vue
import { inject } from 'vue'export default {
name: 'Comp',
setup() {
const $myHttp: any = inject('$myHttp') // inject $myHttpconst getListWithMyHttp = (): void => {
$myHttp
.get(api)
.then((response: { data: any }) => {
console.log(response.data)
});
};const axios2: any = inject('axios2') // inject axios2
const getListWithAxios2 = (): void => {
axios2
.get(api)
.then((response: { data: any }) => {
console.log(response.data)
});
};return { getListWithMyHttp, getListWithAxios2 }
}
}
```