vue实现的请求服务器端API接口示例
2019-05-25 18:02
1376 查看
本文实例讲述了vue实现的请求服务器端API接口。分享给大家供大家参考,具体如下:
import axios from 'axios' import router from '@/router' axios.defaults.timeout = 3000 axios.defaults.baseURL = '' axios.interceptors.request.use( config => { // const token = getCookie('名称') config.data = config.data config.headers = { 'Content-Type': 'application/json; charset=utf-8' } if (config.url === '/api/login/index') { } else { if (localStorage.getItem('Authorization')) { config.headers.Authorizatior = localStorage.getItem('Authorization') } } // if (token) { // config.params = {'token': token} // } return config }, error => { return Promise.reject(error) } ) axios.interceptors.response.use( response => { //返回错误跳转到首页 if (response.data.code === 0) { router.push({ path: '/', querry: { redirect: router.currentRoute.fullPath } }) } return response }, error => { if (error.response) { switch (error.response.status) { case 401: localStorage.removeItem('Authorization') router.push('/login') } } return Promise.reject(error) } ) /** * 封装get方法 * @param url * @param data * @returns {Promise} */ export function fetch (url, params = {}) { return new Promise((resolve, reject) => { axios.get(url, { params: params }) .then(response => { resolve(response.data) }) .catch(err => { reject(err) }) }) } /** * 封装post请求 * @param url * @param data * @returns {Promise} */ export function post (url, data = {}) { return new Promise((resolve, reject) => { axios.post(url, data) .then(response => { resolve(response.data) }, err => { reject(err) }) }) } /** * 封装patch请求 * @param url * @param data * @returns {Promise} */ export function patch (url, data = {}) { return new Promise((resolve, reject) => { axios.patch(url, data) .then(response => { resolve(response.data) }, err => { reject(err) }) }) } /** * 封装put请求 * @param url * @param data * @returns {Promise} */ export function put (url, data = {}) { return new Promise((resolve, reject) => { axios.put(url, data) .then(response => { resolve(response.data) }, err => { reject(err) }) }) }
main.js调用
import { fetch, post, patch, put } from '@/util/fetch' Vue.prototype.get = fetch Vue.prototype.post = post Vue.prototype.patch = patch Vue.prototype.put = put
视图页面使用
export default { name: 'login', data () { return { mobile: '', password: '' } }, components: { XInput, XButton, Group, Box }, methods: { handleLogin () { let params = {} params.username = this.mobile params.password = this.password this.post('/api/driver/index', params).then((data) => { console.log(data) }).catch((error) => { console.log(error) }) } } }
希望本文所述对大家vue.js程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- vue.js实现请求数据的方法示例
- Vue-resource实现ajax请求和跨域请求示例
- (五)快速上手VUE api接口实现示例
- 利用JQuery和Servlet实现跨域提交请求示例分享
- python服务器端收发请求的实现代码
- jsonp跨域请求实现示例
- vue 实现在函数中触发路由跳转的示例
- AJAX实现页面无刷新发表评论(post请求,服务器端使用php)
- Android 下使用 JSON 实现 HTTP 请求,外加几个示例!
- JFinal+Vue 实现 Java 高并发秒杀示例
- Vue.js实现的表格增加删除demo示例
- vue项目tween方法实现返回顶部的示例代码
- 基于Vue实现后台系统权限控制的示例代码
- vue+element UI实现树形表格带复选框的示例代码
- JavaScript实现Ajax请求简单示例
- vue+element实现批量删除功能的示例
- vue-cli实现多页面多路由的示例代码
- vue与bootstrap实现时间选择器的示例代码
- vue 请求接口示例 --小丑
- Python基于分析Ajax请求实现抓取今日头条街拍图集功能示例