Vue简单封装axios之解决post请求后端接收不到参数问题


Posted in Javascript onFebruary 16, 2020

1.在src/下新建api文件夹,api/下新建index.js和public.js

在public.js中:

import axios from 'axios';
import qs from 'qs'
import router from '../router'
import { MessageBox} from 'mint-ui'
// 注意点,按照以下写
var instance = axios.create();
instance.defaults.timeout = 10000;
instance.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
export default {
  fetchGet(url, params = {}) {
    return new Promise((resolve, reject) => {
      axios.get(url, params).then(res => {
        if(res.data.code === 302) {
          MessageBox('提示', '登录失效,请重新登录');
          MessageBox.alert('登录失效,请重新登录', '提示').then(action => {  
            router.push("/login");
          });
        }
        resolve(res.data);
      }).catch(error => {
        reject(error);
      })
    })
  },
  fetchPost(url, params = {}) {
    /* 
    axios post请求后端接收不到参数问题:
    解决方案一:有效,但是兼容性不是很好,不是所有浏览器都支持
      let data = new URLSearchParams()
      for (var key in params) {
        data.append(key, params[key])
      }
    */
    // 解决方案二:使用qs模块(axios中自带),使用qs.stringify()序列化params
    return new Promise((resolve, reject) => {
      axios.post(url, qs.stringify(params)).then(res => {
        resolve(res.data);
      }).catch(error => {
        reject(error);
      })
    })
  }
}

2.在index.js中:

import http from './public'
export const getStation = (params) => {
  return http.fetchGet('/hydro/rest/getBelongUser', params);
}
export const userLogin = (params) => {
  return http.fetchPost("/hydro/rest/login", params);
}

3.在Login.vue中调用post请求方法:

<template>
  <div class="login">
    <h1>登录页面</h1>
    <input type="text" placeholder="请输入用户名" v-model="Username">
    <input type="password" placeholder="请输入密码" v-model="Password">
    <input type="button" value="登录" @click="toLogin">
  </div>
</template>
<script>
import {userLogin} from "../../api/index"
export default {
 name: 'app',
 data() {
  return {
   Username: "",
   Password: ""
  }
 },
 methods: {
  toLogin() {
    let params = {
      username: this.Username,
      password: this.Password
    };
    userLogin(params).then(res => {
      if(res.code === 200) {
        this.$router.push("/home")
      }
    })
  }
 }
}
</script>

#### 4.在Home.vue调用get请求方法

<template>
  <h1 class="home">
    {{stationName}}
  </h1>
</template>
<script>
import {getStation} from "../../api/index"
export default {
  data() {
    return{
      stationName: ""
    }
  },
  created() {
    getStation().then(res => {
      this.stationName = res.msg;
    })
  }
}
</script>

总结

以上所述是小编给大家介绍的Vue简单封装axios之解决post请求后端接收不到参数问题,希望对大家有所帮助!

Javascript 相关文章推荐
JS 自动安装exe程序
Nov 30 Javascript
学习ExtJS Window常用方法
Oct 07 Javascript
js 表格隔行颜色
Dec 02 Javascript
jQuery使用CSS()方法给指定元素同时设置多个样式
Mar 26 Javascript
JavaScript动态修改背景颜色的方法
Apr 16 Javascript
javascript获取文档坐标和视口坐标
May 26 Javascript
浅析angularJS中的ui-router和ng-grid模块
May 20 Javascript
ES6学习笔记之Set和Map数据结构详解
Apr 07 Javascript
axios进阶实践之利用最优雅的方式写ajax请求
Dec 20 Javascript
总结js函数相关知识点
Feb 27 Javascript
用vue-cli开发vue时的代理设置方法
Sep 20 Javascript
微信小程序项目总结之记账小程序功能的实现(包括后端)
Aug 20 Javascript
封装一下vue中的axios示例代码详解
Feb 16 #Javascript
Vue.js的模板语法详解
Feb 16 #Javascript
Vue两个版本的区别和使用方法(更深层次了解)
Feb 16 #Javascript
vue数据响应式原理知识点总结
Feb 16 #Javascript
vue中利用iscroll.js解决pc端滚动问题
Feb 15 #Javascript
JS localStorage存储对象,sessionStorage存储数组对象操作示例
Feb 15 #Javascript
ES6 proxy和reflect的使用方法与应用实例分析
Feb 15 #Javascript
You might like
CI框架源码解读之利用Hook.php文件完成功能扩展的方法
2016/05/18 PHP
laravel框架 api自定义全局异常处理方法
2019/10/11 PHP
php+ajax实现文件切割上传功能示例
2020/03/03 PHP
让任务管理器中的CPU跳舞的js代码
2008/11/01 Javascript
js 数组实现一个类似ruby的迭代器
2009/10/27 Javascript
基于jquery循环map功能的代码
2011/02/26 Javascript
详解vue 模版组件的三种用法
2017/07/21 Javascript
深入理解React高阶组件
2017/09/28 Javascript
详解如何用VUE写一个多用模态框组件模版
2018/09/27 Javascript
JavaScript一元正号运算符示例代码
2019/06/30 Javascript
Vue使用vue-recoure + http-proxy-middleware + vuex配合promise实现基本的跨域请求封装
2019/10/21 Javascript
[01:38]DOTA2辉夜杯 欢乐的观众现场采访
2015/12/26 DOTA
python通过urllib2爬网页上种子下载示例
2014/02/24 Python
python字符串连接的N种方式总结
2014/09/17 Python
python的类方法和静态方法
2014/12/13 Python
python去掉 unicode 字符串前面的u方法
2018/10/21 Python
pandas 快速处理 date_time 日期格式方法
2018/11/12 Python
在python中利用numpy求解多项式以及多项式拟合的方法
2019/07/03 Python
Django文件存储 默认存储系统解析
2019/08/02 Python
python GUI库图形界面开发之PyQt5简单绘图板实例与代码分析
2020/03/08 Python
python爬虫开发之selenium模块详细使用方法与实例全解
2020/03/09 Python
python适合做数据挖掘吗
2020/06/16 Python
python3实现将json对象存入Redis以及数据的导入导出
2020/07/16 Python
Python 忽略文件名编码的方法
2020/08/01 Python
Python常用模块函数代码汇总解析
2020/08/31 Python
利用HTML5+CSS3实现3D转换效果实例详解
2017/05/02 HTML / CSS
abstract class和interface有什么区别?
2012/01/03 面试题
异常和异常类的概念
2014/09/12 面试题
资深财务管理人员自我评价
2013/09/22 职场文书
收款委托书范本
2014/09/11 职场文书
员工试用期自我评价
2014/09/18 职场文书
向国旗敬礼学生寄语大全
2014/09/30 职场文书
教师节老师寄语
2015/05/28 职场文书
民政局未婚证明
2015/06/15 职场文书
2016党员党章学习心得体会
2016/01/14 职场文书
小学科学课教学反思
2016/02/23 职场文书