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!

推薦閱讀: