当前位置 : 主页 > 网络编程 > JavaScript >

Vue项目中安装使用axios全过程

来源:互联网 收集:自由互联 发布时间:2023-02-08
目录 Vue安装使用axios 一、安装 二、引入 三、使用 vue开发使用axios的时候报错 Cannot set property axios of undefined Vue安装使用axios 一、安装 在控制台输入npm install axios -S 二、引入 在文件mai
目录
  • Vue安装使用axios
    • 一、安装
    • 二、引入
    • 三、使用
  • vue开发使用axios的时候报错
    • Cannot set property “axios” of undefined

Vue安装使用axios

一、安装

在控制台输入npm install axios -S

二、引入

在文件main.js中写入

import axios from 'axios';
Vue.prototype.$axios = axios;

三、使用

向cgi-bin/login.cgi提交登录data数据。

注意:

  • 提交的Content-Type要看后端以什么方式接收,然后以相应的方式提交,要不然后端收到的就是被转码的乱码。
  • data的格式按自己要求修改。
//cgi-bin/login.cgi是提交登录的地址

        const qs = require("qs");
        const data = {
          operate: "login",
          psw: this.form.password,
        };
        
        //默认提交方式为Content-Type: application/x-www-form-urlencoded
        this.$axios
          .post('/cgi-bin/login.cgi',
            qs.stringify({
              data: JSON.stringify(data),
            }),
          )
          
          //修改为Content-Type: application/json;charset=UTF-8方式:
          //this.$axios
          //.post(
          //  "/cgi-bin/login.cgi",
          //  // qs.stringify({
           //   data,
          //  // }),
          //  {
          //    headers: {
          //      "Content-Type": "application/json;charset=UTF-8",
           //   },
          //  }
         // )

          .then((result) => {//提交成功
            // console.log("login:"+result);
            // console.log("login2:"+JSON.stringify(result) );
            if (result.data == 'ok') {返回‘ok'
              localStorage.setItem('login', 'ok');//浏览器保存登录成功
              this.$message({
                message: '登陆成功',
                type: 'success',
              });
              this.$router.push('/home');//跳转页面
            } else {
              this.$message.error('密码错误');
            }
          })
          .catch((error) => {//提交失败
            console.log('Error', error.message);
            this.$message.error('服务连接错误');
          });

默认提交方式为Content-Type: application/x-www-form-urlencoded结果:

Content-Type: application/json;charset=UTF-8方式结果:

vue开发使用axios的时候报错

Cannot set property “axios” of undefined

前天写代码的时候,第一次用axios报了一个错,再三检查下,发现代码是没有问题的。然后检查了版本发现了问题。

打开package.json文件,找到对应的版本号。时至今日,axios最新的版本号是3.0.1,所以使用

npm install axios -S
npm install qs -S
npm install vue-axios -S

命令下载的时候会下载最新版本,就有了版本之间的不和谐。

下面是package.json中的版本信息。

 "dependencies": {
    "axios": "^0.20.0",
    "element-ui": "^2.13.2",
    "qs": "^6.9.4",
    "vue": "^2.5.2",
    "vue-axios": "^3.0.1",
    "vue-router": "^3.0.1"
  },

这个时候只需要把其中的"vue-axios": “^3.0.1”, 改成 “vue-axios”: "^2.1.5"就行了。

改完之后,要找到,文件夹中原来下载了的,并进行删除。

比如vue-axios我的是在D:\work\html\spa03\node_modules\vue-axios,就找到删除。

当然,不放心的,删错了的,只要把整个node_modules文件夹删除了就好了。

打开cmd窗口,进入文件夹路径,然后npm i,就可以下载刚刚删除了的所有版块。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持易盾网络。

网友评论