欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

前端如何調(diào)用后端接口進行數(shù)據(jù)交互詳解(axios和SpringBoot)

 更新時間:2023年03月16日 12:02:27   作者:沓然  
一般來講前端不會給后端接口,而是后端給前端接口的情況比較普遍,下面這篇文章主要給大家介紹了關(guān)于前端如何調(diào)用后端接口進行數(shù)據(jù)交互的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

前端調(diào)用后端接口,獲得數(shù)據(jù)并渲染

一、介紹

一個完善的系統(tǒng),前后端交互是必不可少的,這個過程可以分成下面幾步:

前端向后端發(fā)起請求后端接口接收前端的參數(shù)后,開始層層調(diào)用方法處理數(shù)據(jù)后端將最終數(shù)據(jù)返回給前端接口前端請求成功后,將數(shù)據(jù)渲染至界面

對于初學(xué)者而言,前后端交互感覺十分困難,其實并不難,現(xiàn)在,我們做一個小例子,在例子中,大家就明白了。

二、項目結(jié)構(gòu)

前端技術(shù):axios

后端技術(shù):SpringBoot(這個也無所謂,但是你一定要有控制層的訪問路徑,也就是所謂的請求地址對應(yīng)的方法,可以用SSM框架,SSH框架,都可以)

上面是大致的文件結(jié)構(gòu),相信大家后端的數(shù)據(jù)處理都沒問題,無非就是:

  • 控制層接收前端請求,調(diào)用對應(yīng)的業(yè)務(wù)層接口方法
  • 業(yè)務(wù)層實現(xiàn)類去實現(xiàn)業(yè)務(wù)層接口
  • 業(yè)務(wù)層實現(xiàn)類的方法內(nèi)調(diào)用數(shù)據(jù)層的接口
  • 數(shù)據(jù)層實現(xiàn)文件(mapper.xml)實現(xiàn)數(shù)據(jù)層接口
  • 然后處理結(jié)果層層返回

三、代碼編寫

我們只介紹前端界面+控制層,首先是前端界面

第一步:引入相關(guān)文件

這里的axios就是我們發(fā)起請求所必備的文件,這些文件在文章末尾會有給出。

前端代碼如下:

<%@ 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() {  //一加載界面就調(diào)用
        $.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;
    }

很明顯,大家看看應(yīng)該就明白了,前端發(fā)請求時可以攜帶數(shù)據(jù),比如賬號、密碼啊等等,后端接收后,就可以處理啦,然后把處理結(jié)果返回給前端,

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

效果:

四、運用

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

前端代碼:

 <el-dialog title="創(chuàng)建車輛裝備" :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="庫存數(shù)量" 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數(shù)據(jù)
            insertVisible:false //新增提示框控制器:true顯示/false隱藏
        },
        methods:{
            //打開新增提示框
            openInsertPanel:function(){
                this.insertVisible = true;
                this.equipment = {};
            },
            //創(chuàng)建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;
    }

以上就是新增功能的運用

例子很簡單,但是用處很大,登錄校驗、數(shù)據(jù)展示、增刪改查都是這種流程,后端返回的數(shù)據(jù)類型不僅僅是Int,List和對象都是可以的。
下面給出文件地址,大家需要的自己下載:

jquery.min.js: jquery.min.js

axios.min.js: axios.min.js

總結(jié)

到此這篇關(guān)于前端如何調(diào)用后端接口進行數(shù)據(jù)交互(axios和SpringBoot)的文章就介紹到這了,更多相關(guān)前端調(diào)用后端接口數(shù)據(jù)交互內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JavaWeb基礎(chǔ)教程之Java基礎(chǔ)加強版

    JavaWeb基礎(chǔ)教程之Java基礎(chǔ)加強版

    這篇文章主要介紹了JavaWeb基礎(chǔ)教程之Java基礎(chǔ)加強版的相關(guān)資料,需要的朋友可以參考下
    2016-07-07
  • Java模擬單鏈表和雙端鏈表數(shù)據(jù)結(jié)構(gòu)的實例講解

    Java模擬單鏈表和雙端鏈表數(shù)據(jù)結(jié)構(gòu)的實例講解

    這篇文章主要介紹了Java模擬單鏈表和雙端鏈表數(shù)據(jù)結(jié)構(gòu)的實例,注意這里的雙端鏈表不是雙向鏈表,是在單鏈表的基礎(chǔ)上保存有對最后一個鏈接點的引用,需要的朋友可以參考下
    2016-04-04
  • javaweb實戰(zhàn)之商城項目開發(fā)(三)

    javaweb實戰(zhàn)之商城項目開發(fā)(三)

    這篇文章主要針對javaweb商城項目開發(fā)進行實戰(zhàn)演習(xí),主要實現(xiàn)通用的BaseDao.java和使用resultMap映射關(guān)聯(lián)對象,感興趣的小伙伴們可以參考一下
    2016-02-02
  • 詳細分析JVM類加載機制

    詳細分析JVM類加載機制

    JVM將class文件字節(jié)碼文件加載到內(nèi)存中,?并將這些靜態(tài)數(shù)據(jù)轉(zhuǎn)換成方法區(qū)中的運行時數(shù)據(jù)結(jié)構(gòu),在堆(并不一定在堆中,HotSpot在方法區(qū)中)中生成一個代表這個類的java.lang.Class?對象,作為方法區(qū)類數(shù)據(jù)的訪問入口,接下來將詳細講解JVM類加載機制
    2022-04-04
  • Mybatis批量修改聯(lián)合主鍵數(shù)據(jù)的兩種方法

    Mybatis批量修改聯(lián)合主鍵數(shù)據(jù)的兩種方法

    最近遇上需要批量修改有聯(lián)合主鍵的表數(shù)據(jù),找很多資料都不是太合適,最終自己摸索總結(jié)了兩種方式可以批量修改數(shù)據(jù),對Mybatis批量修改數(shù)據(jù)相關(guān)知識感興趣的朋友一起看看吧
    2022-04-04
  • Java繪圖庫JFreeChart的使用教程

    Java繪圖庫JFreeChart的使用教程

    圖表是一種以簡單方式顯示信息的圖形,JFreeChart允許創(chuàng)建各種交互式和非交互式圖表,本文主要介紹了Java繪圖庫JFreeChart的使用教程,感興趣的可以了解一下
    2023-09-09
  • Java并發(fā)之synchronized實現(xiàn)原理深入理解

    Java并發(fā)之synchronized實現(xiàn)原理深入理解

    這篇文章主要介紹了Java中synchronized實現(xiàn)原理詳解,涉及synchronized實現(xiàn)同步的基礎(chǔ),Java對象頭,Monitor,Mark Word,鎖優(yōu)化,自旋鎖等相關(guān)內(nèi)容,具有一定借鑒價值,需要的朋友可以參考下
    2021-08-08
  • Linux下Java開發(fā)環(huán)境搭建以及第一個HelloWorld

    Linux下Java開發(fā)環(huán)境搭建以及第一個HelloWorld

    這篇文章主要介紹了Linux下Java開發(fā)環(huán)境搭建以及第一個HelloWorld的實現(xiàn)過程,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2015-09-09
  • Springcloud?feign傳日期類型參數(shù)報錯的解決方案

    Springcloud?feign傳日期類型參數(shù)報錯的解決方案

    這篇文章主要介紹了Springcloud?feign傳日期類型參數(shù)報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • springboot的logging.group日志分組方法源碼流程解析

    springboot的logging.group日志分組方法源碼流程解析

    這篇文章主要為大家介紹了springboot的logging.group日志分組方法源碼流程解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12

最新評論