SpringBoot+VUE實現數據表格的實戰
前言
還記得第一次做項目時,因為不會將數據庫表中的數據渲染到前端而頭疼,最後還是靠layui提供的數據表格API實現瞭前端數據表格的渲染。一直到現在做瞭很多SpringBoot項目、SSM項目之後,現在返回頭來看這個曾經這個讓我備受折磨的問題,腦海中下意識就會想到很多種解決的方法,比如導入前端的數據表格、通過JavaScript渲染數據表格、通過VUE來渲染數據表格…本文將使用VUE+SpringBoot+MybatisPlus,以前後端分離的形式來實現數據表格在前端的渲染,在此做下記錄,便於以後進行回顧。
使用的開發工具:
- 前端:HBuilderX
- 後端:IntelliJ IDEA
本次要進行渲染的數據庫內容如下:
提示:以下是本篇文章正文內容,下面案例可供參考
一、前端準備
1. 基礎界面
在前端先將頁面寫好,在這裡我按照數據庫表格中的字段順序依次填寫
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>showDataList</title> </head> <body> <div id="app" align="center"> <table border="1" width="48%" style="text-align: center;"> <tr> <td colspan="5"> <h1>用戶列表</h1> </td> </tr> <tr> <td>編號</td> <td>姓名</td> <td>性別</td> <td>年齡</td> </tr> </table> </div> </body> </html>
顯示效果:
2. 導入JS文件
在這裡我導入瞭VUE和Axios的JS文件,在HTML的<head>
標簽中引入相應的JS文件 (axios起的作用和Ajax是相同的,使用axios是因為在做項目的過程中axios相較於Ajax來說很好的解決瞭回調地獄的問題)
<script src="static/js/vue.js"></script> <script src="static/js/axios.js"></script>
導入瞭JS文件後,準備<script>
標簽用來準備VUE對象和axios進行數據傳輸
<script>
標簽中的代碼如下:
<script> // 設定axios的請求前綴 axios.defaults.baseURL = "http://localhost:8090" // 指定VUE的渲染區域 const app = new Vue({ el: "#app", data: { }, methods: { } }) </script>
代碼解釋:
axios.defaults.baseURL = "http://localhost:8090"
在前後端分離的項目中,前端每一次向後端傳輸數據時都要指定HTTP協議以及端口號,這行代碼定義瞭請求前綴,之後axios傳輸數據時都默認加上瞭雙引號中的內容
const app = new Vue({...})
這段代碼中指定瞭VUE要渲染的區域,el對應內容是id為app的div圖層,data為指定數據的區域,methods為定義方法的區域
二、後端準備
新建SpringBoot項目並配置MybatisPlus,配置MybatisPlus的過程就不在此贅述
1. 創建實體類
在後端pojo包下新建User實體類,實體類中的屬性要與數據庫中的字段對應一致。
@Data @Accessors(chain = true) @TableName("demo_user") public class User implements Serializable { @TableId(type = IdType.AUTO) private Integer id; // 如果屬性與字段同名(包括駝峰規則)註解可以省略 private String name; private Integer age; private String sex; }
代碼解釋:
@Data
為lombok插件提供的註解,自動為屬性提供瞭get/set/toString等方法@Accessors(chain = true)
也是lombok插件提供的註解,開啟鏈式編程@TableName("demo_user")
為MybatisPlus提供的註解,用於指定該實體類對應數據中的哪張表@TableId(type = IdType.AUTO)
用來指定實體類中的哪個屬性作為表中的主鍵,並且主鍵自增實現瞭Serializable
接口的作用是將該實體類序列化,將實體類序列化的目的是為瞭保證數據在傳輸的過程中不會出錯
2. Controller層
在創建好實體類後,開始寫Controller層的代碼
@RestController @CrossOrigin @RequestMapping("/table") public class TableController { @Autowired private UserService userService; @GetMapping("/getAllUser") public List<User> getAllUser() { List<User> userList = userService.selectAll(); return userList; } }
代碼解釋:
- 在Controller層中添加
@CrossOrigin
註解的作用是支持跨域 @RestController
相當於@Controller
和@ResponseBody
兩個註解的結合,將後端的數據以JSON串的格式返回到前端
3. Service層
①. UserService接口
public interface UserService { /** * 查詢數據庫對應表中所有的數據 * * @return 集合對象 */ List<User> selectAll(); }
②. UserServiceImpl實現類
@Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; /** * 查詢數據庫中所有的集合 * * @return 集合對象 */ @Override public List<User> selectAll() { List<User> userList = userMapper.selectList(null); return userList; } }
在MybatisPlus中,selectList方法的參數為空時會查詢當前表中的所有數據
4. Mapper層
①. UserMapper接口
public interface UserMapper extends BaseMapper<User> { }
②. UserMapper.xml文件
<?xml version="1.0" encoding="utf-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" > <mapper namespace="cn.shijimo.mapper.UserMapper"> </mapper>
在MybatisPlus中SQL語句可以自動生成
三、前後端整合
完成前端和後端的基本配置之後,接下來進行前後端分離項目的整合,在進行整合時先對實現過程進行分析
1. 當用戶點擊顯示表格按鈕時就應該發起Ajax請求獲取userList數據
2. 將UserList中的數據在頁面中展現(頁面中的數據必須在data中定義)
3. 將請求的結果賦值給data屬性
4. 利用v-for指令實現數據的遍歷
對<script>
代碼塊中VUE的代碼進行編輯:
因為後端的返回值是一個集合,所以首先在data數據域中定義userList數組對象用來接收從後端傳來的集合,接著在methods方法區域中定義一個方法getUserList,該方法中要進行axios向後端發起請求,並將返回的數據存儲到數組對象中。在HTML的<table>
標簽中添加一個按鈕組件,為按鈕綁定getUserList方法。
添加完按鈕組件之後,在<table>
標簽中也添加<tr>
標簽,使用VUE中的v-for指令來對userList集合進行遍歷,依次取出並進行渲染。
<script> // 設定axios的請求前綴 axios.defaults.baseURL = "http://localhost:8090" // 指定VUE的渲染區域 const app = new Vue({ el: "#app", data: { // 定義集合來存儲數據, 此時數據為null userList: [] }, methods: { // 1. 定義getUserList方法 獲取後臺服務器數據 async getUserList() { // 新增操作請求的類型: post 接收時需要使用JSON方式處理 let { data: result } = await axios.get("/table/getAllUser") // Ajax調用之後, 將請求結果賦值給data屬性 this.userList = result } } }) </script>
<table border="1" width="48%" style="text-align: center;"> <tr> <td colspan="5"> <h1>用戶列表</h1> </td> </tr> <tr> <td colspan="5" style="text-align: left;"> <button type="button" @click="getUserList">顯示表格</button> </td> </tr> <tr> <td>編號</td> <td>姓名</td> <td>性別</td> <td>年齡</td> </tr> <tr v-for="user in userList"> <td v-text="user.id"></td> <td v-text="user.name"></td> <td v-text="user.sex"></td> <td v-text="user.age"></td> </tr> </table>
代碼解釋:
在這裡使用v-text指令不使用插值表達式(即{{}})的原因是因為如果傳輸的數據很多的話,在沒有顯示完之前頁面上會顯示{{XXX}},不利於瀏覽器的安全。
至此前後端整合完畢。
四、運行結果
表中的內容就全部顯示在瞭前端,最後再用bootstrap進行修飾美化
總結
以上就是使用SpringBoot + VUE + Mybatis實現瞭數據表格的渲染,更多相關SpringBoot+VUE數據表格內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- spring boot寫java web和接口
- SSM VUE Axios詳解
- Spring實現聲明式事務的方法詳解
- Vue的異步渲染axios問題
- springboot+mybatis-plus實現內置的CRUD使用詳解