A simple and declarative way to fetch data for Vue components.
- Small-size, only 800 bytes gzipped
- Fetch and compose data in a declarative way
yarn add vue-fetch-data
An example component which fetches a GitHub user:
import Vue from 'vue'
import FetchData from 'vue-fetch-data'
Vue.use(FetchData)
<template>
<div>
<div v-if="user.pending">Loading...</div>
<div v-if="user.fulfilled">{{ user.value.login }}</div>
<div v-if="user.rejected">{{ user.reason.message }}</div>
</div>
</template>
<script>
export default {
props: ['username'],
// make sure you set the initial value of that property to `{}`
data: () => ({ user: {} }),
fetch: {
user: vm => `https://api.github.com/users/${vm.username}`
}
}
</script>
Then boom, check out live demo at https://vue-fetch-data.surge.sh
The fetch
in component options is an Object
which is similar to computed
option.
The value of each entry can be string
Object
or a function which returns those. The returned Object
could contain any axios option, the returned string
will be used as url
and fetched in GET
method.
export default {
fetch: {
user() {
return `https://api.github.com/users/${this.username}`
},
article: 'https://get-article-api.com/api/get_post',
users: {
url: 'https://get-users/api/users',
method: 'POST',
data: {
offset: 20
}
}
}
}
Refetch in every poll
ms:
export default {
fetch: {
posts: vm => ({
url: '/api/posts',
poll: 1000, // update every second
params: {
limit: vm.limit,
offset: vm.offset
}
})
}
}
Instead of updating data in current component, you can use commit
to commit a Vuex mutation:
export default {
computed: {
...mapState(['user'])
},
fetch: {
user: {
commit: 'UPDATE_USER',
url: '/user/egoist'
}
}
}
And your vuex store would look like:
{
state: {
user: {}
},
mutation: {
UPDATE_USER(state, payload) {
state.user = payload
}
}
}
You can also manually trigger it:
export default {
data: () => ({username: 'egoist', user: {}}),
fetch: {
user: vm => `/api/user/${vm.username}`
}
watch: {
username() {
this.$fetch('user')
}
}
}
Access axios
directly, which means you can do this.$http.get/post
and such in component.
It's just like Promise
- pending: initial state, not fulfilled or rejected.
- fulfilled: meaning that the operation completed successfully.
- rejected: meaning that the operation failed.
- value: the data which is fetched by the request
- reason: the reason(Error) why the request failed
- Fork it!
- Create your feature branch:
git checkout -b my-new-feature
- Commit your changes:
git commit -am 'Add some feature'
- Push to the branch:
git push origin my-new-feature
- Submit a pull request :D
vue-fetch-data © egoist, Released under the MIT License.
Authored and maintained by egoist with help from contributors (list).
egoistian.com · GitHub @egoist · Twitter @_egoistlily