前端如何调用后端接口进行数据交互(极简)
阿里云国内75折 回扣 微信号:monov8 |
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6 |
前端调用后端接口获得数据并渲染
一、介绍
一个完善的系统前后端交互是必不可少的这个过程可以分成下面几步
- 前端向后端发起请求
- 后端接口接收前端的参数后开始层层调用方法处理数据
- 后端将最终数据返回给前端接口
- 前端请求成功后将数据渲染至界面
对于初学者而言前后端交互感觉十分困难其实并不难现在我们做一个小例子在例子中大家就明白了。
二、项目结构
前端技术axios
后端技术SpringBoot这个也无所谓但是你一定要有控制层的访问路径也就是所谓的请求地址对应的方法可以用SSM框架SSH框架都可以
上面是大致的文件结构相信大家后端的数据处理都没问题无非就是
- 控制层接收前端请求调用对应的业务层接口方法
- 业务层实现类去实现业务层接口
- 业务层实现类的方法内调用数据层的接口
- 数据层实现文件mapper.xml实现数据层接口
- 然后处理结果层层返回
三、代码编写
我们只介绍前端界面+控制层首先是前端界面
第一步引入相关文件
这里的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;
}
以上就是新增功能的运用
例子很简单但是用处很大登录校验、数据展示、增删改查都是这种流程后端返回的数据类型不仅仅是IntList和对象都是可以的。
下面给出文件地址大家需要的自己下载
jquery.min.js: jquery.min.js
axios.min.js: axios.min.js
最后整理不易别忘点赞关注
有想了解更全面的可以评论及时出教程