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 相关文章推荐
jquery聚焦文本框与扩展文本框聚焦方法
Oct 12 Javascript
jquery 按钮状态效果 正常、移上、按下
Aug 12 Javascript
jQuery实现拖拽效果插件的方法
Mar 23 Javascript
果断收藏9个Javascript代码高亮脚本
Jan 06 Javascript
在 Angular 中实现搜索关键字高亮示例
Mar 21 Javascript
AngularJS 限定$scope的范围实例详解
Jun 23 Javascript
video.js 实现视频只能后退不能快进的思路详解
Aug 09 Javascript
Vue瀑布流插件的使用示例
Sep 19 Javascript
解决IE11 vue +webpack 项目中数据更新后页面没有刷新的问题
Sep 25 Javascript
使用vue-cli3新建一个项目并写好基本配置(推荐)
Apr 24 Javascript
vue中data改变后让视图同步更新的方法
Mar 29 Vue.js
如何理解Vue前后端数据交互与显示
May 10 Vue.js
封装一下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
Zend Framework常用校验器详解
2016/12/09 PHP
CI框架实现框架前后端分离的方法详解
2016/12/30 PHP
PHP5.0 TIDY_PARSE_FILE缓冲区溢出漏洞的解决方案
2018/10/14 PHP
JQuery魔力之$(&quot;tagName&quot;)与selector
2012/03/05 Javascript
onkeypress字符按键兼容所有浏览器使用介绍
2013/04/24 Javascript
js关闭浏览器窗口及检查浏览器关闭事件
2013/09/03 Javascript
nodejs教程之入门
2014/11/21 NodeJs
jQuery+css实现百度百科的页面导航效果
2014/12/16 Javascript
js实现仿京东2级菜单效果(带延时功能)
2015/08/27 Javascript
基于JavaScript实现移动端点击图片查看大图点击大图隐藏
2015/11/04 Javascript
Javascript类型系统之String字符串类型详解
2016/06/21 Javascript
jquery点击切换背景色的简单实例
2016/08/25 Javascript
AngularJS 2.0入门权威指南
2016/10/08 Javascript
javascript创建对象的3种方法
2016/11/02 Javascript
浅谈struts1 &amp; jquery form 文件异步上传
2017/05/25 jQuery
vue实现样式之间的切换及vue动态样式的实现方法
2017/12/19 Javascript
基于vue-cli vue-router搭建底部导航栏移动前端项目
2018/02/28 Javascript
在小程序中集成redux/immutable/thunk第三方库的方法
2018/08/12 Javascript
对Vue table 动态表格td可编辑的方法详解
2018/08/28 Javascript
从零开始实现Vue简单的Toast插件
2018/12/03 Javascript
解决微信小程序云开发中获取数据库的内容为空的方法
2019/05/15 Javascript
微信小程序开发中var that =this的用法详解
2020/01/18 Javascript
基于JavaScript实现留言板功能
2020/03/16 Javascript
python使用logging模块发送邮件代码示例
2018/01/18 Python
Python OpenCV对本地视频文件进行分帧保存的实例
2019/01/08 Python
基于torch.where和布尔索引的速度比较
2020/01/02 Python
Python OpenCV去除字母后面的杂线操作
2020/07/05 Python
django数据模型中null和blank的区别说明
2020/09/02 Python
python 利用matplotlib在3D空间中绘制平面的案例
2021/02/06 Python
Travelstart沙特阿拉伯:廉价航班、豪华酒店和实惠的汽车租赁优惠
2019/04/06 全球购物
学生自我鉴定模板
2013/12/30 职场文书
羽毛球社团活动总结
2014/06/27 职场文书
资源环境与城乡规划管理专业自荐书
2014/09/26 职场文书
2016大学迎新晚会开场白
2015/11/24 职场文书
2016暑期师德培训心得体会
2016/01/09 职场文书
Python使用Opencv打开笔记本电脑摄像头报错解问题及解决
2022/06/21 Python