前端如何调用后端接口进行数据交互详解(axios和SpringBoot)

作者:沓然 时间:2023-10-17 02:48:43 

前端调用后端接口,获得数据并渲染

一、介绍

一个完善的系统,前后端交互是必不可少的,这个过程可以分成下面几步:

前端向后端发起请求后端接口接收前端的参数后,开始层层调用方法处理数据后端将最终数据返回给前端接口前端请求成功后,将数据渲染至界面

对于初学者而言,前后端交互感觉十分困难,其实并不难,现在,我们做一个小例子,在例子中,大家就明白了。

二、项目结构

前端技术:axios

后端技术:SpringBoot(这个也无所谓,但是你一定要有控制层的访问路径,也就是所谓的请求地址对应的方法,可以用SSM框架,SSH框架,都可以)

前端如何调用后端接口进行数据交互详解(axios和SpringBoot)

上面是大致的文件结构,相信大家后端的数据处理都没问题,无非就是:

  • 控制层接收前端请求,调用对应的业务层接口方法

  • 业务层实现类去实现业务层接口

  • 业务层实现类的方法内调用数据层的接口

  • 数据层实现文件(mapper.xml)实现数据层接口

  • 然后处理结果层层返回

三、代码编写

我们只介绍前端界面+控制层,首先是前端界面

第一步:引入相关文件

前端如何调用后端接口进行数据交互详解(axios和SpringBoot)

这里的axios就是我们发起请求所必备的文件,这些文件在文章末尾会有给出。

前端代码如下:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
   <title>测试</title>
   <script src="../static/js/jquery.min.js"></script>
   <script src="../static/js/axios.min.js"></script>
</head>
<body>
<span id="text">我是前端默认值</span>
<script>
   window.onload =function() {  //一加载界面就调用
       $.ajax({url:"testTest?num=1",success:function(result){
               document.getElementById("text").innerHTML=result;
           }});
   };
</script>
</body>
</html>

后端控制层代码如下:

@RequestMapping("/testTest")  //控制层
   @ResponseBody
   public int testTest(int num) {
       if(num==1) return 1;
       if(num==2) return 2;
       return 0;
   }

很明显,大家看看应该就明白了,前端发请求时可以携带数据,比如账号、密码啊等等,后端接收后,就可以处理啦,然后把处理结果返回给前端,

前端接收后,就可以渲染了,或者给出操作成功的提示。

效果:

前端如何调用后端接口进行数据交互详解(axios和SpringBoot)

四、运用

1、字符串、整形等(新增功能)

前端代码:

<el-dialog title="创建车辆装备" :visible.sync="insertVisible" width="30%">
       <el-form :model="equipment" ref="equipment" label-width="100px" class="demo-ruleForm">
           <el-form-item label="名称" prop="name">
               <el-input v-model="equipment.name"></el-input>
           </el-form-item>
           <el-form-item label="类型" prop="type">
               <el-input v-model="equipment.type"></el-input>
           </el-form-item>
           <el-form-item label="库存数量" prop="inventory">
               <el-input type="number" v-model="equipment.inventory"></el-input>
           </el-form-item>
       </el-form>
       <span slot="footer" class="dialog-footer">
               <el-button @click="insertVisible = false">取 消</el-button>
               <el-button type="primary" @click="insertEquipment" data-toggle="modal" data-target="#myModal">确 定</el-button>
             </span>
   </el-dialog>
<script type="text/javascript">
   new Vue({
       el:"#box",
       data:{
           id:"",//装备主键
           equipment:{},//一条equipment数据
           insertVisible:false //新增提示框控制器:true显示/false隐藏
       },
       methods:{
           //打开新增提示框
           openInsertPanel:function(){
               this.insertVisible = true;
               this.equipment = {};
           },
           //创建equipment
           insertEquipment:function(){
               var name = this.equipment.name;
               var type = this.equipment.type;
               var inventory = this.equipment.inventory;
               var that = this;
               axios.put("insertEquipment?name="+name+"&type="+type+"&inventory="+inventory).then(function(result){
                   if(result.data.status){
                       that.selectAllEquipment();
                       that.insertVisible = false;
                   }else{
                       that.$message.error(result.data.message);
                       that.insertVisible = false;
                   }

});
           },
       }
   });
</script>

后端代码

@RequestMapping("/insertEquipment")  //增加装备
   @ResponseBody
   public ResultMap insertEquipment(String name, String type,String inventory) {
       try {
           int realInventory=Integer.valueOf(inventory);
           Equipment equipment=new Equipment(name,type,realInventory);
           equipmentService.insertEquipment(equipment);
           resultMap.setStatus(true);
       } catch (Exception e) {
           resultMap.setStatus(false);
           resultMap.setMessage(e.getMessage());
       }
       return resultMap;
   }

来源:https://blog.csdn.net/weixin_43005654/article/details/123568085

标签:前端,后端,数据交互
0
投稿

猜你喜欢

  • Java中常用的设计模式之装饰器模式详解

    2021-08-28 07:59:15
  • Spring Boot配置Thymeleaf(gradle)的简单使用

    2023-04-18 07:41:42
  • MyBatis中一对多的xml配置方式(嵌套查询/嵌套结果)

    2023-11-16 16:34:23
  • SpringBoot整合MybatisPlus实现增删改查功能

    2022-10-31 05:24:15
  • Android天气预报app改进版

    2023-12-04 05:54:07
  • 基于Android SDK-在64位Linux中使用需要注意的问题

    2022-03-26 16:49:13
  • Android编程之canvas绘制各种图形(点,直线,弧,圆,椭圆,文字,矩形,多边形,曲线,圆角矩形)

    2023-10-16 12:16:14
  • Netty分布式获取异线程释放对象源码剖析

    2021-12-28 09:45:42
  • Android启动画面的实现方法

    2023-12-27 23:22:11
  • 详解C# 反射(Reflection)

    2021-09-08 14:42:59
  • SpringCloud网关组件zuul实例解析

    2023-04-13 08:51:47
  • android实现密码框右侧显示小眼睛

    2023-01-26 19:54:59
  • Java框架之Maven SSM集合

    2022-04-05 16:22:54
  • Java关键字volatile详析

    2023-01-21 21:51:11
  • Mybatis中的高级映射一对一、一对多、多对多

    2022-05-11 05:22:39
  • 利用POI生成EXCEL文件的方法实例

    2023-11-23 21:44:14
  • 详解Java关键字final

    2023-11-29 09:10:27
  • 使用spring注入枚举类型作为参数

    2023-11-23 13:25:57
  • Java 多用户登录限制的实现方法

    2022-04-06 07:32:46
  • Java开发岗位面试被问到反射怎么办

    2023-01-07 00:09:12
  • asp之家 软件编程 m.aspxhome.com