SpringBoot项目的html页面使用axios进行get post请求

简介: SpringBoot项目的html页面使用axios进行get post请求

说明:本项目为SpringBoot项目而不是vue项目,本项目用于练习axios使用get及post请求
get和post请求都采用两种方式进行配置,并注明易错点

@[toc]

1.axios是什么

Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中,axios是对ajax的一种封装,而jquery也是对ajax的一种封装。
axios的github:https://github.com/axios/axios

2.vue项目为什么使用axios,而不使用jquery?

axios集成vue更好且占内存小,而如果只用jquery的ajax的话,毕竟几百k,$表达式也不用情况下显得太笨重了,因此vue项目使用axios居多且集成的更好。

3.SpringBoot项目的html页面引入axios方式,采用script引入

<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
AI 代码解读

至于网上说的方案,对springboot项目测试无效
import axios from ‘axios’;
//安装方法
npm install axios
//或
bower install axios

4.官网为方便起见,为所有支持的请求方法提供了别名

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]])
AI 代码解读

5.get请求的两种方式

使用方式1(推荐) => axios.get();
注意1:headers请求头设置位置不一样,axios.get()中headers存在于{}中,而axios({})中headers当成一个key,value进行设置。
注意2:get请求参数封装与params对象中。

axios.get("/getVue", {
           params: {
               name:"zhangsan"
           },
           headers: {
               responseType: 'json'    //响应数据格式为"json"
           }
       }).then((res)=>{
           myForm.formMess.name = res.data.info.name;
           myForm.formMess.password = res.data.info.password;
           alert("查询数据成功!")
       }).catch(err => {
           console.log(err);   //打印响应数据(错误信息)
       });
AI 代码解读

使用方式2 => axios({})

axios({
     method:"get",
      url:"/getVue",
      params:{
          name:"zhangsan"
      },
      headers: {
          responseType: 'json'    //响应数据格式为"json"
      }
  }).then((res)=>{
      myForm.formMess.name = res.data.info.name;
      myForm.formMess.password = res.data.info.password;
      alert("查询数据成功!")
  }).catch(err => {
      console.log(err);    //打印响应数据(错误信息)
  });
AI 代码解读

6.post请求的两种方式

使用方式1(推荐) => axios.post();
注意点1:headers请求头设置位置不一样,axios.post()中headers存在于第三个{}中,而axios({})中headers当成一个key,value进行设置。
注意点2:axios.post()的第二个{}指代请求体中没有作为key的data,而axios({})中使用data作为请求体参数。

axios.post("/addVue", {
    "name":this.formMess.name,
    "password":this.formMess.password
     },{
         headers: {
             responseType: 'json'
         }
     }).then((res)=>{
         console.log(res);
         alert("提交数据成功!")
     }).catch(err => {
         console.log(err);    //打印响应数据(错误信息)
     });
AI 代码解读

使用方式2 => axios({})

axios({
     method:"post",
     url:"/addVue",
     data:{
         "name":this.formMess.name,
         "password":this.formMess.password,
     },
     header:{
         responseType: 'json'    //响应数据格式为"json"
     }
 }).then((res)=>{
     console.log(res);
     alert("提交数据成功!")
 }).catch(err => {
     console.log(err);   //打印响应数据(错误信息)
 });
AI 代码解读

本人相关其他文章链接

1.JQuery选择器+DOM操作+事件+DOM与JQuery对象间的转化

2.个人练习前端技术使用Bootstrap、JQuery、thymeleaf

3.JavaScript入门及基础知识介绍

4.AJax(XHR+Get和Post+AJax的封装)

5.SpringBoot项目的html页面使用axios进行get post请求

目录
打赏
0
1
2
0
230
分享
相关文章
SpringBoot 响应请求是串行还是并行?
Spring Boot 在默认情况下通过 Servlet 容器的线程池实现并行处理 HTTP 请求。通过适当的线程池配置,可以进一步优化并发性能。此外,Spring Boot 提供了异步处理机制(如使用 `@Async` 注解)和反应式编程模型(Spring WebFlux),使得应用能够处理更高的并发负载。在具体项目中,可以根据需求选择合适的处理模型,以充分利用 Spring Boot 的并发处理能力。
76 21
如何利用HTML和CSS构建企业级网站的全过程。从项目概述到页面结构设计,再到HTML结构搭建与CSS样式设计,最后实现具体页面并进行优化提升,全面覆盖了网站开发的关键步骤
本文深入介绍了如何利用HTML和CSS构建企业级网站的全过程。从项目概述到页面结构设计,再到HTML结构搭建与CSS样式设计,最后实现具体页面并进行优化提升,全面覆盖了网站开发的关键步骤。通过实例展示了主页、关于我们、产品展示、新闻动态及联系我们等页面的设计与实现,强调了合理布局、美观设计及用户体验的重要性。旨在为企业打造一个既专业又具吸引力的线上平台。
162 7
SpringBoot项目的html页面使用axios进行get post请求
SpringBoot项目的html页面使用axios进行get post请求
69 0
【Vue面试题二十五】、你了解axios的原理吗?有看过它的源码吗?
这篇文章主要讨论了axios的使用、原理以及源码分析。 文章中首先回顾了axios的基本用法,包括发送请求、请求拦截器和响应拦截器的使用,以及如何取消请求。接着,作者实现了一个简易版的axios,包括构造函数、请求方法、拦截器的实现等。最后,文章对axios的源码进行了分析,包括目录结构、核心文件axios.js的内容,以及axios实例化过程中的配置合并、拦截器的使用等。
【Vue面试题二十五】、你了解axios的原理吗?有看过它的源码吗?
【Vue面试题二十七】、你了解axios的原理吗?有看过它的源码吗?
文章讨论了Vue项目目录结构的设计原则和实践,强调了项目结构清晰的重要性,提出了包括语义一致性、单一入口/出口、就近原则、公共文件的绝对路径引用等原则,并展示了单页面和多页面Vue项目的目录结构示例。
在vue前端开发中基于refreshToken和axios拦截器实现token的无感刷新
在vue前端开发中基于refreshToken和axios拦截器实现token的无感刷新
380 4

物联网

+关注
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等