日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

SpringBoot+VUE實現數據表格的實戰

瀏覽:131日期:2023-02-20 14:16:52
目錄前言使用的開發工具:一、前端準備1. 基礎界面2. 導入JS文件二、后端準備1. 創建實體類2. Controller層3. Service層4. Mapper層三、前后端整合四、運行結果總結前言

還記得第一次做項目時,因為不會將數據庫表中的數據渲染到前端而頭疼,最后還是靠layui提供的數據表格API實現了前端數據表格的渲染。一直到現在做了很多SpringBoot項目、SSM項目之后,現在返回頭來看這個曾經這個讓我備受折磨的問題,腦海中下意識就會想到很多種解決的方法,比如導入前端的數據表格、通過JavaScript渲染數據表格、通過VUE來渲染數據表格…本文將使用VUE+SpringBoot+MybatisPlus,以前后端分離的形式來實現數據表格在前端的渲染,在此做下記錄,便于以后進行回顧。

使用的開發工具: 前端:HBuilderX 后端:IntelliJ IDEA

本次要進行渲染的數據庫內容如下:

SpringBoot+VUE實現數據表格的實戰

提示:以下是本篇文章正文內容,下面案例可供參考

一、前端準備1. 基礎界面

在前端先將頁面寫好,在這里我按照數據庫表格中的字段順序依次填寫

<!DOCTYPE html><html><head><meta charset='utf-8'><title>showDataList</title></head><body><div align='center'><table border='1' 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>

顯示效果:

SpringBoot+VUE實現數據表格的實戰

2. 導入JS文件

在這里我導入了VUE和Axios的JS文件,在HTML的<head>標簽中引入相應的JS文件 (axios起的作用和Ajax是相同的,使用axios是因為在做項目的過程中axios相較于Ajax來說很好的解決了回調地獄的問題)

<script src='http://m.b3g6.com/bcjs/static/js/vue.js'></script><script src='http://m.b3g6.com/bcjs/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實現類

@Servicepublic 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: {// 定義集合來存儲數據, 此時數據為nulluserList: []},methods: {// 1. 定義getUserList方法 獲取后臺服務器數據async getUserList() {// 新增操作請求的類型: post接收時需要使用JSON方式處理let {data: result} = await axios.get('/table/getAllUser')// Ajax調用之后, 將請求結果賦值給data屬性this.userList = result}}})</script>

<table border='1' 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}},不利于瀏覽器的安全。至此前后端整合完畢。

四、運行結果

SpringBoot+VUE實現數據表格的實戰

SpringBoot+VUE實現數據表格的實戰

SpringBoot+VUE實現數據表格的實戰

表中的內容就全部顯示在了前端,最后再用bootstrap進行修飾美化

SpringBoot+VUE實現數據表格的實戰

總結

以上就是使用SpringBoot + VUE + Mybatis實現了數據表格的渲染,更多相關SpringBoot+VUE數據表格內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
毛片不卡一区二区| 日韩精品一二区| 免费看久久久| 国产精品久久久久久久久免费高清 | 成人免费电影网址| 国产精品麻豆久久| 色婷婷亚洲mv天堂mv在影片| 久久男人av资源站| 久久精品导航| 国产亚洲精品自拍| 久久亚洲视频| 另类av一区二区| 日韩中文字幕1| 日韩成人一级| 久久av导航| 人人草在线视频| 在线视频观看日韩| 美女少妇全过程你懂的久久| 亚洲免费激情| 视频一区日韩| 国产精品美女在线观看直播| 激情综合五月| 99久久www免费| 免费日本视频一区| 欧美日韩网址| 麻豆视频在线观看免费网站黄| 久久九九精品| 国产精品普通话对白| 日韩**一区毛片| 国产一区二区三区四区大秀| 深夜福利视频一区二区| 亚洲精品1区| 91亚洲无吗| 水蜜桃久久夜色精品一区| 亚洲成人精品| 亚洲久久视频| 福利一区视频| 日韩视频在线一区二区三区| 欧美精品三级在线| 久久影院午夜精品| 麻豆亚洲精品| 久久麻豆视频| 999国产精品999久久久久久| 亚洲精品乱码日韩| 国产在线一区不卡| 欧美专区18| 久久av影视| 免费毛片在线不卡| 欧美亚洲一级| 久久国产亚洲精品| 日韩动漫一区| 丝袜av一区| 欧美永久精品| 久久国产日本精品| 欧美影院精品| 久久国产欧美| 国产探花一区在线观看| 在线看片国产福利你懂的| 视频一区在线视频| 国产一区二区三区探花| 麻豆成人在线| 91一区二区三区四区| 亚洲91网站| 欧美日韩一二三四| 国产欧美日韩精品一区二区三区| 亚洲福利精品| 精品一区二区三区亚洲| 亚洲理论在线| 久久精品官网| 久久av网址| 在线免费观看亚洲| 久久精品亚洲欧美日韩精品中文字幕| 日韩精品成人在线观看| se01亚洲视频| 国产精品综合色区在线观看| 亚洲尤物在线| jizzjizz中国精品麻豆| 亚洲欧洲国产精品一区| 久久久久国产精品一区三寸| 国产日韩欧美三级| 亚洲资源网站| 米奇777超碰欧美日韩亚洲| 精品国产亚洲日本| 日韩高清在线不卡| 国产精品丝袜xxxxxxx| 久久激情婷婷| 国产精品成人a在线观看| 亚洲人妖在线| 久久高清免费观看| 九一精品国产| 国产精品精品| 国产精品久久久久久av公交车| 首页亚洲欧美制服丝腿| 欧美1级日本1级| 日韩国产专区| 国产一区丝袜| 久久精品午夜| 国产精品亚洲综合久久| 五月激激激综合网色播| 午夜宅男久久久| 国产一区日韩一区| 中文字幕人成乱码在线观看| 日本三级亚洲精品| 亚洲欧洲美洲国产香蕉| 亚洲欧美视频| 国产视频一区欧美| 欧美日韩国产探花| 激情欧美一区| 香蕉精品久久| 久久伦理在线| 国内精品99| 欧美网站在线| 五月天久久久| 免费久久精品| 亚洲精品在线观看91| 日韩精品一区二区三区免费观看| 欧美日韩国产观看视频| 麻豆精品蜜桃视频网站| 免费视频一区二区三区在线观看| 国产欧美日韩一级| 国产精成人品2018| 免费亚洲一区| 狠狠久久伊人| 欧产日产国产精品视频| 久久久国产亚洲精品| 欧美一区二区三区高清视频| 国产伊人精品| 99国产精品| 中文字幕亚洲影视| 亚洲精品国产精品粉嫩| 日韩精品一区二区三区中文| 7m精品国产导航在线| 欧美欧美黄在线二区| 国产日本精品| 精品视频网站| 日韩大片在线观看| 欧美久久精品一级c片| 国产午夜久久| 日韩国产在线观看一区| 国产极品一区| 日韩欧美视频专区| 2023国产精品久久久精品双| 久久成人一区| 日韩精品视频在线看| 国产精品国码视频| 国产 日韩 欧美 综合 一区| 久久久国产亚洲精品| 免费不卡中文字幕在线| 水蜜桃久久夜色精品一区的特点 | 日本欧美不卡| 黄色不卡一区| 亚洲精品亚洲人成在线观看| 欧美日韩一区二区三区不卡视频| 国产精品videossex| 福利在线免费视频| 在线国产一区| 日韩精品亚洲aⅴ在线影院| 国产精品15p| 99热精品久久| 日本大胆欧美人术艺术动态| 欧美日韩亚洲国产精品| 中文字幕在线官网| 美女精品一区| 国产精品欧美一区二区三区不卡| 亚洲免费福利| 日本大胆欧美人术艺术动态| 欧美激情日韩| 国内精品99| 国产视频一区二区在线播放| 日韩不卡免费高清视频| 无码日韩精品一区二区免费| 国产第一亚洲| 久久xxxx精品视频| 久久久久伊人| 日韩中文影院| 日韩精品视频一区二区三区| 91视频一区| 日日夜夜免费精品| 久久久男人天堂| 婷婷成人av| 91精品精品| 国产精品主播在线观看| 欧美~级网站不卡| 国产精品1luya在线播放| 在线国产一区二区| 美女视频一区在线观看| 欧美综合国产| 伊人久久视频| 日韩成人av影视| 久久久天天操| 国产欧美另类| 亚洲一区区二区| 岛国av在线网站| 91欧美日韩在线| 美女少妇全过程你懂的久久| 麻豆精品少妇| 日韩欧美中文字幕在线视频| 久久国产日韩| 精品九九久久| 婷婷综合福利|