前端如何调用后端接口进行数据交互(极简)

Posted 沓然

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了前端如何调用后端接口进行数据交互(极简)相关的知识,希望对你有一定的参考价值。

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

一、介绍

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

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

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

二、项目结构

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


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

  1. 控制层接收前端请求,调用对应的业务层接口方法
  2. 业务层实现类去实现业务层接口
  3. 业务层实现类的方法内调用数据层的接口
  4. 数据层实现文件(mapper.xml)实现数据层接口
  5. 然后处理结果层层返回

三、代码编写

我们只介绍前端界面+控制层,首先是前端界面
第一步:引入相关文件

这里的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;
    

很明显,大家看看应该就明白了,前端发请求时可以携带数据,比如账号、密码啊等等,后端接收后,就可以处理啦,然后把处理结果返回给前端,前端接收后,就可以渲染了,或者给出操作成功的提示。
效果:

四、运用

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;
    

以上就是新增功能的运用

例子很简单,但是用处很大,登录校验、数据展示、增删改查都是这种流程,后端返回的数据类型不仅仅是Int,List和对象都是可以的。
下面给出文件地址,大家需要的自己下载:
jquery.min.js: jquery.min.js
axios.min.js: axios.min.js

最后,整理不易,别忘点赞关注!
有想了解更全面的,可以评论,及时出教程!

前端Vue和Element-UI配合后端接口进行数据交互

前言

本次用element-ui的table组件,简单案例演示下前后端数据交互。

前提声明:如果不知道如何在vue中引入element-ui,可以先看下这篇文章:Vue引入并使用Element-UI组件库的两种方式

静态页面

首先先写一个静态页面吧,数据都是死的,这也是element-ui的table组件demo:

直接把代码复制到组件里面即可。

这样一个静态组件就写好了

但是这样只是一个静态的,我们开发中往往需要通过接口进行数据交互的。所以需要调用接口把数据改成动态的

动态页面

接口支持

前提是必须有后端服务器的接口支持,我在本地简单的编写了一个用户列表接口。

为了保证接口正常,使用调用测试一下,就是这样的一个返回结果

注意返回结果格式,前端需要根据接口的返回格式获取内容或数据的

前端我使用的是axios发送请求的,如果不知道怎么引用和使用axios,可以参考这篇文章:Vue安装并使用axios发送请求

调用接口

使用axios发送请求接口数据,使用函数封装,并且在挂载钩子调用函数,这样就能在页面加载的时候展示数据了:


这样一个动态的table就出来了:

下面是相关的代码:

由于我自己封装的接口返回信息里面有一个data,所以这里需要取两层data才能得到数据!

<template>
  <el-table :data="tableData"  highlight-current-row  border stripe style="width: 100%" class="userTable">
    <!-- <el-table-column prop="id" label="id" width="90" align="center"></el-table-column> -->
    <el-table-column
      prop="userName"
      label="姓名"
      width="90"
      align="center"
    ></el-table-column>
  <el-table-column
      prop="sex"
      label="性别"
      width="90"
      align="center"
    ></el-table-column>
    <el-table-column
      prop="account"
      label="账号"
      width="180"
      align="center"
    ></el-table-column>
    <el-table-column
      prop="password"
      label="密码"
      width="180"
      align="center"
    ></el-table-column>
    <el-table-column
      prop="imnage"
      label="头像"
      width="90"
      align="center"
    ></el-table-column>
    <el-table-column
      prop="phone"
      label="手机号"
      width="130"
      align="center"
    ></el-table-column>
    <el-table-column
      prop="remark"
      label="备注"
      width="180"
      align="center"
    ></el-table-column>
    <el-table-column
      prop="status"
      label="状态"
      width="90"
      align="center"
    ></el-table-column>
    <el-table-column
      prop="birthday"
      label="生日"
      width="180"
      align="center"
    ></el-table-column>
    <el-table-column
      prop="createTime"
      label="创建时间"
      width="180"
    ></el-table-column>
    <el-table-column
      prop="updateTime"
      label="修改时间"
      width="180"
    ></el-table-column>
  </el-table>
</template>

<script>
// 引入axios
import axios from "axios";
export default 
  name: "App",
  data() 
    return 
      tableData: [],
    ;
  ,
  methods: 
    queryUserList() 
      axios.get("http://localhost:9090/user/queryList").then(
        // 成功回调
        (success) => 
          console.log("请求成功!");
          // 请求成功后的数据
          console.log(success);
          this.tableData = success.data.data;
        ,
        // 失败回调
        (error) => 
          console.log("请求失败!");
          // 请求失败原因
          console.log(error.message);
        
      );
    ,
  ,
  mounted() 
    this.queryUserList();
  ,
;
</script>

<style  scoped>

</style>



总结

这就是一个基本的前端调用后端查询,因为我是后端开发,对前端不是很专业,这是我做个人项目中遇到的一个问题。分享给你,希望对你有用

后续的话也会分享vue增删改查基本的代码。

以上是关于前端如何调用后端接口进行数据交互(极简)的主要内容,如果未能解决你的问题,请参考以下文章

前端提供给后端一个接口是啥意思

前端Vue和Element-UI配合后端接口进行数据交互

vue为什么会访问两次后端接口呢

sqlserver后端接口最好的语言

后端给前端的接口文档里面的url是接口地址吗

vue中,前端如何保存后端的接口返回值