首頁 >Java >java教程 >axios和SpringBoot前端怎麼呼叫後端介面進行資料交互

axios和SpringBoot前端怎麼呼叫後端介面進行資料交互

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB轉載
2023-05-13 10:34:132268瀏覽

一、介紹

一個完善的系統,前後端互動是不可或缺的,這個過程可以分成下面幾步:

前端向後端發起請求後端介面接收前端的參數後,開始層層呼叫方法處理資料後端將最終資料回傳給前端介面前端請求成功後,將資料渲染至介面

二、專案結構

前端技術: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;
    }

以上是axios和SpringBoot前端怎麼呼叫後端介面進行資料交互的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除