zoukankan      html  css  js  c++  java
  • AXIOS 常用请求方式总结

    Axios

    中文文档
    http://axios-js.com/
    https://www.runoob.com/vue2/vuejs-ajax-axios.ht=ml
    

    配置全局请求 URL

    // 配置全局请求 URL
    axios.defaults.baseURL="http://localhost:8080";
    

    GET

    用于获取资源

    仅发送请求体头

    axios.get("/student", {
        params: {
            name: "Lucy",
            age: 10,
            state: false,
        }
    }).then(res => {
        console.log(res)
    }).catch(err => {
        console.error(err);
    })
    
    // 简写方式
    axios.get("/student?name=Lucy&age=10&state=false")
        .then(res => {
            console.log(res)
        }).catch(err => {
            console.error(err);
        })
    
    @GetMapping("/student")
    public void test(String name,Integer age,Boolean state) {
        System.err.println("name="+name+" age="+age+" state="+state);
    }
    

    POST

    用于发送资源

    仅发送请求体 JSON

    // 常用方式
    axios.post("/student", {
        name: "Lucy",
        age: 10,
        state: false,
    }).then(res => {
        console.log(res)
    }).catch(err => {
        console.error(err);
    })
    
    //其它写法
    axios({
        method: 'post',
        url: '/student',
        data: {
            name: "Lucy",
            age: 10,
            state: false
        }
    }).then(res => {
        console.log(res)
    }).catch(err => {
        console.error(err);
    })
    
    
    @RequestMapping("/student")
    public void test(@RequestBody Student student) {
        System.err.println(student);
    }
    

    同时传递请求头与请求体

    axios({
        method: 'post',
        url: '/student',
        params: {
            message: "请求头"
        },
        data: {
            name: "Lucy",
            age: 10,
            state: false
        }
    }).then(res => {
        console.log(res)
    }).catch(err => {
        console.error(err);
    })
    
    @RequestMapping("/student")
    public void test(String message,@RequestBody Student student) {
        System.err.println(message);
        System.err.println(student);
    }
    

    DELETE

    用于删除资源

    仅发送请求体 JSON

    axios.delete('/student', {
        data: {
            name: "Lucy",
            age: 10,
            state: false
        }
    }).then((response) => {
        console.log(error);
    }).catch(function (error) {
        console.log(error);
    });
    
    @PutMapping("/student")
    public void test(@RequestBody Student student) {
        System.err.println(student);
    }
    

    同时发送请求头与请求体

    axios.delete('/student', {
        params: {
            message: "message~~"
        },
        data: {
            name: "Lucy",
            age: 10,
            state: false,
        }
    }).then((response) => {
        console.log(error);
    }).catch(function (error) {
        console.log(error);
    });
    
    @DeleteMapping("/student")
    public void test(String message,@RequestBody Student student) {
        System.err.println(message);
        System.err.println(student);
    }
    

    PUT

    用于完成的更新资源

    仅发送请求体 JSON

    axios.put('/student', {
        name: "Lucy",
        age: 10,
        state: false,
    }).then((response) => {
        console.log(error);
    }).catch(function (error) {
        console.log(error);
    });
    
    @PutMapping("/student")
    public void test(@RequestBody Student student) {
        System.err.println(student);
    }
    

    同时发送请求头与请求体

    axios({
        method: 'put',
        url: '/student',
        params: {
            message: "message~~~"
        },
        data: {
            name: "Lucy",
            age: 10,
            state: false
        }
    }).then(res => {
        console.log(res)
    }).catch(err => {
        console.error(err);
    })
    
    @PutMapping("/student")
    public void test(String message,@RequestBody Student student) {
        System.err.println(message);
        System.err.println(student);
    }
    

    PATCH

    用于更新局部资源

    仅发送请求体 JSON

    axios.patch('/student', {
        name: "Lucy",
        age: 10,
        state: false
    }).then((response) => {
        console.log(error);
    }).catch(function (error) {
        console.log(error);
    });
    
    @PatchMapping("/student")
    public void test(@RequestBody Student student) {
        System.err.println(student);
    }
    

    同时发送请求头与请求体

    axios({
        method: 'patch',
        url: '/student',
        params: {
            message: "message~~~"
        },
        data: {
            name: "Lucy",
            age: 10,
            state: false
        }
    }).then(res => {
        console.log(res)
    }).catch(err => {
        console.error(err);
    })
    
    @PatchMapping("/student")
    public void test(String message,@RequestBody Student student) {
        System.err.println(message);
        System.err.println(student);
    }
    

    AXIOS 的响应结构

    {
      // `data` 由服务器提供的响应
      data: {},
      // `status`  HTTP 状态码
      status: 200,
      // `statusText` 来自服务器响应的 HTTP 状态信息
      statusText: "OK",
      // `headers` 服务器响应的头
      headers: {},
      // `config` 是为请求提供的配置信息
      config: {}
    }
    

    通用请求方式

    axios({
        //method 默认为 GET  [参数支持 GET POST DELETE HEAD OPTIONS PUT PATCH}
        method: 'get',
        url: '/user',
        // 请求 API 的父路径
        baseURL: 'https://some-domain.com/api/',
        params: {
            ID: 12345
        },
        // data 作为请求主体被发送的 JSON 数据 只适用于这些请求方法 'PUT', 'POST', 'PATCH'
        data: {
            firstName: 'Fred'
        },
        // timeout 指定请求超时的毫秒数(0 表示无超时时间)
        timeout: 1000
    }).then(res => {
        console.log(res)
    }).catch(err => {
        console.error(err);
    })
    

    并发执行请求

    function getUserAccount() {
      return axios.get('/user/12345');
    }
    
    function getUserPermissions() {
      return axios.get('/user/12345/permissions');
    }
    
    axios.all([getUserAccount(), getUserPermissions()])
      .then(axios.spread(function (acct, perms) {
        // 两个请求现在都执行完成
      }));
    

    支持请求方法的别名

    axios.request(config)
    axios.get(url[, config])
    axios.delete(url[, config])
    axios.head(url[, config])
    axios.post(url[, data[, config]])
    axios.put(url[, data[, config]])
    axios.patch(url[, data[, config]])
    
  • 相关阅读:
    打标签tag
    高阶函数
    anywhere执行时端口被占用Address already in use:8080解决方法
    时间戳常见转化
    generator(生成器)
    Promise详解(转载)
    在手机上预览自己的本地h5页面
    箭头函数中的this
    扩展运算符
    38.线程
  • 原文地址:https://www.cnblogs.com/Haidnor/p/13863711.html
Copyright © 2011-2022 走看看