Vue+elementUI表格组件使用(table代码详细分析)

墨蓝 2023-10-05 09:57 143阅读 0赞

【辰兮要努力】:hello你好我是辰兮,很高兴你能来阅读,昵称是希望自己能不断精进,向着优秀程序员前行!

博客来源于项目以及编程中遇到的问题总结,偶尔会有读书分享,我会陆续更新Java前端、后台、数据库、项目案例等相关知识点总结,感谢你的阅读和关注,希望我的博客能帮助到更多的人,分享获取新知,大家一起进步!

吾等采石之人,应怀大教堂之心,愿你们奔赴在各自的热爱中…

本篇是Vue+elementUI的使用案例前端代码解析

学习本章要有一点点前端基础,才能更好的阅读

20200912102841131.png_pic_center

在git上下载了一个前端案例,商品列表表格显示如下

20200910203406276.png_pic_center
代码分析:

如图我们显示出来的表格就是el-table中包含的元素
在这里插入图片描述

1、特别要注意的是这里的prop一定要和后台传来的参数是一致的

比如你后台传来goods_name 你这里写成good_name 那么该表格是无法识别的 当前小框就会显示为空

2、关于表格比如你后台查询出来的一个商品Vo有10个属性,但是你前端只想显示5个属性,其它属性就被隐藏的包含在这一行当中了

这边我在编辑按钮打印一下这一行商品的相关信息 用alter弹出来让看的更加清楚

  1. //编辑按钮的方法
  2. edit(row){
  3. //弹出一下这个对象的相关信息
  4. alert(JSON.stringify(row));
  5. }

JSON.stringify(row)就是将对象转换成json串打印出来 ,不然打印出来的是object

20200910203159445.png_pic_center

如上向商品id,创建时间,商品数量,更新时间等属性其实都是绑定在当前行的。这些属性可显示!可隐藏!一直存在!

3、比如我们要删除某一个商品可以根据商品id

如何获取商品id ?-> row.商品id

在这里插入图片描述

row就代表当前行的对象,通过对象.属性,在前端,你可以获取任何该商品前端存在属性。


代码分析:

整理了一下本页面加载方法的基本含义,比较基础

在这里插入图片描述

本页代码详情

  1. <template>
  2. <div>
  3. <el-breadcrumb separator-class="el-icon-arrow-right">
  4. <el-breadcrumb-item :to="{ path: '/home' }">首页</el-breadcrumb-item>
  5. <el-breadcrumb-item>商品管理</el-breadcrumb-item>
  6. <el-breadcrumb-item>商品列表</el-breadcrumb-item>
  7. </el-breadcrumb>
  8. <el-card>
  9. <el-row :gutter="20">
  10. <el-col :span="8">
  11. <el-input
  12. placeholder="请输入内容"
  13. clearable
  14. v-model="queryInfo.query"
  15. @clear="getGoodsList"
  16. >
  17. <el-button
  18. slot="append"
  19. icon="el-icon-search"
  20. @click="handleCurrentChange(1)"
  21. ></el-button>
  22. </el-input>
  23. </el-col>
  24. <el-col :span="4">
  25. <el-button type="primary" @click="goAddPage">添加商品</el-button>
  26. </el-col>
  27. </el-row>
  28. <el-table :data="goodslist" stripe border style="width: 100%">
  29. <el-table-column type="index"> </el-table-column>
  30. <el-table-column prop="goods_name" label="商品名称"></el-table-column>
  31. <el-table-column prop="goods_price" label="商品价格(元)" width="95px"></el-table-column>
  32. <el-table-column prop="goods_weight" label="商品重量" width="70px"></el-table-column>
  33. <el-table-column prop="add_time" label="创建时间" width="170px">
  34. <template v-slot="scope">
  35. {
  36. {
  37. scope.row.add_time | dateFormat }}
  38. </template>
  39. </el-table-column>
  40. <el-table-column label="操作" width="130px">
  41. <template v-slot="scope">
  42. <el-button size="mini" type="primary" icon="el-icon-edit" @click="edit(scope.row)"></el-button>
  43. <el-button size="mini" type="warning" icon="el-icon-delete" @click="removeById(scope.row.goods_id)"></el-button>
  44. </template>
  45. </el-table-column>
  46. </el-table>
  47. <el-pagination
  48. @size-change="handleSizeChange"
  49. @current-change="handleCurrentChange"
  50. :current-page="queryInfo.pagenum"
  51. :page-sizes="[10, 20, 50]"
  52. :page-size="queryInfo.pagesize"
  53. layout="total, sizes, prev, pager, next, jumper"
  54. :total="total"
  55. background
  56. >
  57. </el-pagination>
  58. </el-card>
  59. </div>
  60. </template>
  61. <script>
  62. export default {
  63. data() {
  64. return {
  65. queryInfo: {
  66. query: "",
  67. pagenum: 1,
  68. pagesize: 10
  69. },
  70. goodslist: [],
  71. total: 0
  72. };
  73. },
  74. created() {
  75. this.getGoodsList();
  76. },
  77. methods: {
  78. async getGoodsList() {
  79. const {
  80. data } = await this.$http.get("goods", {
  81. params: this.queryInfo
  82. });
  83. if (data.meta.status !== 200) {
  84. return this.$message.error(data.meta.msg);
  85. }
  86. this.goodslist = data.data.goods;
  87. this.total = data.data.total;
  88. },
  89. handleSizeChange(newSize) {
  90. this.queryInfo.pagesize = newSize;
  91. this.getGoodsList();
  92. },
  93. handleCurrentChange(newPage) {
  94. this.queryInfo.pagenum = newPage;
  95. this.getGoodsList();
  96. },
  97. // eslint-disable-next-line no-unused-vars
  98. edit(row){
  99. alert(JSON.stringify(row));
  100. },
  101. removeById(id) {
  102. this.$confirm("此操作将永久删除该商品, 是否继续?", "提示", {
  103. confirmButtonText: "确定",
  104. cancelButtonText: "取消",
  105. type: "warning"
  106. })
  107. .then(async () => {
  108. const {
  109. data } = await this.$http.delete(`goods/${
  110. id}`);
  111. if (data.meta.status !== 200) {
  112. return this.$message.error(data.meta.msg);
  113. }
  114. this.getGoodsList();
  115. this.$message({
  116. type: "success",
  117. message: "删除成功!"
  118. });
  119. })
  120. .catch(() => {
  121. this.$message({
  122. type: "info",
  123. message: "已取消删除"
  124. });
  125. });
  126. },
  127. goAddPage() {
  128. this.$router.push("goods/add");
  129. }
  130. }
  131. };
  132. </script>
  133. <style lang="less" scoped></style>

The best investment is to invest in yourself.

在这里插入图片描述

2020.09.12 秋天是个收获的季节,我们更高处见!

发表评论

表情:
评论列表 (有 0 条评论,143人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Table表格

          table表格现状     主要用在网页布局上,但是随着Web2.0时代的到来,表格已经被摒弃了,现在主要开始使用的是“DIV+CSS”模式。      常用的

    相关 表格 table(会使用)

    第01阶段.前端基础.表格 HTML 第二天目标 能够利用表格、列表和表单完成注册页面的综合案例 能出说表格用来做什么的 能说出列表用来做什么的 能说出表单用来做什么...