02 elementplus前端增删改查【小白入门SpringBoot+Vue3】

视频教程来源于 B站青戈
https://www.bilibili.com/video/BV1H14y1S7YV

只用elementplus,学点增删改查,还没有于后端连接起来,具体在下一篇

搭建一个小页面,显示数据

补充:webstorm格式化代码,修改了快捷键 Alt + F

利用elementplus官网的组件,来到src/views/HomeView.vue ,先搭建一个小按钮,使用el-button标签,然后加一个表格标签。这是静态页面

<template>
  <div class="box">
    <el-button class="button" type="primary" round>按钮</el-button>
    <el-table :data="tableData" style="width: 100%">
      <el-table-column prop="date" label="Date" width="180"/>
      <el-table-column prop="name" label="Name" width="180"/>
      <el-table-column prop="address" label="Address"/>
    </el-table>
  </div>
</template>

<style>
.box{
  margin: 20px;
}
</style>

紧接着,在表格里面加点数据,官网里面就有的

<script setup>
const tableData = [
  {
    date: '2016-05-03',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
  {
    date: '2016-05-02',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
  {
    date: '2016-05-04',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
  {
    date: '2016-05-01',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
]
</script>

讲讲,为什么上面这样子加入数据,能完全对应到表格中。

<el-table-column prop="date"/> 表格每列数据,有个prop属性,其属性值是date,然后加入数据的时候,date: '2016-05-02' ,里面的date就是属性值,这样就能把’2016-05-02’,对应放到 prop="date"这一列。其他列同理。


<el-table-column label="Date"/> ,label=“Date”,表示这一列,显示给用户看的列名为Date ,也可以改成中文“日期”


<el-table-column width="180"/> ,width=“180”,表示这一列的宽度为180 ,可以根据需要更改。若删除width=“180”,那么列宽由系统自适应。


增加数据

预想,点击按钮,增加数据,有个弹窗,让用户填写要增加的数据。

弹窗,用Dialog 组件,如下图,点击红框处,会弹出一个表单,是我们想要的内容a6

在这里插入图片描述

然后就复制对应代码,放到src/views/HomeView.vue

  <!-- Form -->
  <el-dialog v-model="dialogFormVisible" title="Shipping address">
    <el-form :model="form">
      <el-form-item label="Promotion name" :label-width="formLabelWidth">
        <el-input v-model="form.name" autocomplete="off" />
      </el-form-item>
      <el-form-item label="Zones" :label-width="formLabelWidth">
        <el-select v-model="form.region" placeholder="Please select a zone">
          <el-option label="Zone No.1" value="shanghai" />
          <el-option label="Zone No.2" value="beijing" />
        </el-select>
      </el-form-item>
    </el-form>
    <template #footer>
      <span class="dialog-footer">
        <el-button @click="dialogFormVisible = false">Cancel</el-button>
        <el-button type="primary" @click="dialogFormVisible = false">
          Confirm
        </el-button>
      </span>
    </template>
  </el-dialog>    

上面只是复制粘贴,得到静态页面,真正实现点击弹窗表单,还需要在js写代码。
elementplus官网也有对应的js的代码,可以参考写进去,相应的reactive, ref也要导入才能正常使用。

  • ref表示数据是响应式的,若有更改,会及时改变。但凡用到ref类型的数据值,必须加value

  • dialogFormVisible 的值是布尔值,true或false

import {reactive, ref} from "vue";
const dialogFormVisible = ref(false)      //表单是否弹出来
const form = reactive({})  //表单数据

接着,弹窗出来的表单,需根据实际情况,进行相应更改。

  • 对照官网的弹窗表单效果图,可发现,label="Promotion name",label的值,对应弹窗表单的左边文本;
  • 于是,可以对照上面表格的的列信息,修改弹窗表单的左边文本。
  • 相应地,label-width表示表单左边文本的宽度,文本宽度可以统一写在上一级标签元素,即<el-form :model="form" label-width="100px">
 原本
<el-form :model="form" >
 <el-form-item label="Promotion name" :label-width="formLabelWidth">
  <el-input v-model="form.name" autocomplete="off"/>
 <el-form-item>
      
修改后
<el-form :model="form" label-width="80px" style="padding-right: 40px">
 <el-form-item label="日期">
  <el-input v-model="form.date" autocomplete="off"/>
 <el-form-item>
  • title=“Shipping address” ,title对应弹窗的标题文本们可以按需修改,即title=“信息”
原本
<el-dialog v-model="dialogFormVisible" title="Shipping address">
    
修改
<el-dialog v-model="dialogFormVisible" title="信息">
  • 弹窗表单的按钮文本,默认是英文"Cancel",修改为中文“取消” 。Confirm翻译为“确认”
原本
<el-button @click="dialogFormVisible = false">Cancel</el-button>

修改
<el-button @click="dialogFormVisible = false">取消</el-button>

如下图可以明显看出修改的属性值,在弹窗显示中做出了相应改变。

在这里插入图片描述


弹窗的表单静态页面信息编辑好了,还需要把点击”增加数据“按钮,出来弹窗的功能做好,修改按钮的代码如下。

原始
<el-button class="button" type="primary" round >按钮</el-button>

修改
<el-button class="button" type="primary" round @click="dialogFormVisible=true">新增数据</el-button>

下个功能。

弹出表单窗口,填写好数据,点击”确认“按钮后,需要把数据插入到表格中。那么在“确认”按钮中,加入监听函数。

原始的
<el-button type="primary" @click="dialogFormVisible = false">确认</el-button>

修改后
<el-button type="primary" @click="save">确认</el-button>

相应地,要把save函数具体实现什么功能的代码写到js。

tableData.push()函数可以把数据插入到表格末尾(补充,tableData名字来源于 <el-table :data="tableData"> ,这表格的数据绑定在tableData上)。

但是push函数插入的数据类型要求一致,tableData此时是对象类型数据,而我们的from表单数据是reactive类型,类型不匹配。

为了保持类型一致,必须改变其中一个类型。所以改变tableData的类型,改为reactive响应式数据。

<script setup>
const tableData = reactive([
  {
    date: '2016-05-03',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
  {
    date: '2016-05-02',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },

])

const save = ()=>{
  // 向表格添加数据
  tableData.push(form);
  // 关闭弹窗
  dialogFormVisible.value = true; 
}

</script>

发现了问题。

关闭弹窗后,再打开,仍然保留上次输入的数据,这样不行。每次打开弹窗,输入框的数据需要保持清空。

为了实现这个功能,需要增加一个函数。

原来
<el-button class="button" type="primary" round @click="dialogFormVisible=true">新增数据</el-button>

修改
<el-button class="button" type="primary" round @click="handleAdd()">新增数据</el-button>

handleAdd()函数对应的js代码

// form改成let类型,是因为const数据原则上不可更改,但是let可以
let form = reactive({})

const handleAdd = ()=>{
  // 打开弹窗
  dialogFormVisible.value=true;
 //  清空数据。这样子不会指向上次的遗留数据 ,还会清空上次遗留的数据。
  form = reactive({})
}

编辑、删除数据

在页面上,增加“编辑”、“删除”。去elementplus官网寻找合适的样式组件,如下图,看中了右边红色框中的样式

在这里插入图片描述

复制对应代码,并适当修改。

补充:

  • 在Vue3中,#default="scope"是一种用于处理列表渲染的语法。它允许在父组件中定义一个插槽,并通过子组件将数据传递给插槽。这样就可以在父组件中使用子组件的数据,并根据需要进行渲染。
  • scope.row→拿到每一行的数据
  • scope.$index→拿到每一行的index
  • @click.prevent函数会阻止触发dom的原始事件,而去执行特定的事件
原始
<el-table-column fixed="right" label="Operations" width="120">
   <template #default>
     <el-button link type="primary" size="small" @click="handleClick">Detail</el-button>
     <el-button link type="primary" size="small">Edit</el-button>
   </template>
 </el-table-column>

修改
<el-table-column fixed="right" label="操作" width="120">
  <template #default="scope">
    <el-button link type="primary" size="small" @click="handleClick(scope.row)">修改</el-button>
   <el-button link type="danger" size="small" @click.prevent="remove(scope.$index)">删除</el-button>
  </template>
</el-table-column>

修改细节如下;

  • <el-table-column label="Operations" > , 新增列,其列名为“操作”,故修改label=“操作”
  • <template #default> ,为了让列表的数据可以传递 ,故#default=“scope”
  • <el-button>Detail</el-button> ,按钮名字分别改为“修改”和“删除”。故<el-button>修改</el-button>
  • @click=“handleClick” ,为了让”修改“按钮和”删除“按钮实现相应的功能,需要添加对应参数,正好利用上#default="scope"的功能。故@click=“handleClick(scope.row)”,以及,@click.prevent=“remove(scope.$index)”
  • <el-button link type="primary"> ,”删除“按钮的样式,为了区分+不轻易删除,故改为醒目的样式,故type="danger">

页面效果如下
在这里插入图片描述

静态页面搭建好了,要把涉及到的函数实现。

先实现删除操作,其实elementplus官网有删除操作的js代码,可以复制过来修改。修改好后,删除操作就实现了。

原始(index: number  这个是typesccript语法,number表示参数的类型)
const deleteRow = (index: number) => {
  tableData.value.splice(index, 1)
}

修改
const remove = (index) => {
   //splice函数 从index的位置开始,删除一行  。 删掉value,是因为tableData数据现在是reactive类型
  tableData.splice(index, 1)
}

接下来搞编辑操作。

const handleEdit = (row)=>{
  // 先把这行数据放进弹出表单里
  form = reactive(row)
  // 再打开表单
  dialogFormVisible.value =true
}

上面的代码已经能实现编辑数据了,但是有一个缺点。就是打开表单窗口编辑的时候,表格对应这一行的数据也立马改变。

这样不对,应该是,提交确认按钮后,修改对应这一行的数据。

所以,还要修改代码。

可以先创建一个空对象,把这行对应的数据存储在这个空对象里面,等确认编辑好后,再把编辑好的数据放进这一行。

与此同时,这个函数还需要一个参数scope.$index ,新增一个变量globaIndex。具体代码修改如下

<el-button link type="primary" size="small" @click="handleEdit(scope.row , scope.$index)">修改</el-button>

let globalIndex = ref(-1) //全局变量

const save = () => {
  if (globalIndex.value > -1) { //编辑数据 。保存表格中,某行编辑好的数据
    tableData[globalIndex.value] = form;
    globalIndex.value = -1
  } e             lse { //新增数据
    // 向表格添加数据
    tableData.push(form);
  }
  // 关闭弹窗
  dialogFormVisible.value = false;
}

const handleEdit = (row, index) => {
  //创建一个空对象,把这行的的数据存储在这个空对象里面,等确认编辑好后,再改变表格对应这一行的数据。
  const newObj = Object.assign({}, row)
  // 把这行数据放进准备弹出表单里
  form = reactive(newObj)
  globalIndex.value = index;
  // 再打开弹出表单
  dialogFormVisible.value = true
}

重点!!!!let globalIndex = ref(-1) //全局变量,但凡用到globalIndex的值的时候,必须加上.vaalue


查询数据

在表格上面,加入一个输入框和一盒查询按钮。

刚开始这是静态页面,但是需要加入查询功能。

补充:

  • ref 和reactive都是响应式类型,但是ref适用于单一数字、字符串、布尔值等简单数据,reactive更适合对象、数组等复杂数据
  • clearable 属性用于在输入框内末尾添加删除图标,可用于清空当前输入框内容
  • v-model=“input” ,Vue中使用v-model指令来实现表单元素和数据的双向绑定。监听用户的输入,然后更新数据
原来
<el-input placeholder="Please input" />
<el-button class="button" type="primary">按钮</el-button>
修改
<el-input v-model="input" placeholder="请输入" style="width: 250px" clearable/>
<el-button class="button" type="primary" round @click="search" style="margin: 5px">查询数据</el-button>

相应地,实现search函数的js代码.

tableData从reactive类型,改会ref类型。因为reactive类型很难用filter函数查出的是代理Proxy数据,没办法将筛选结果赋值给tableData。所以还是改回ref,注意,涉及到tableData的时候,就要加上.value

let input_search = ref('') //初始值为空
let tableData = ref([
  {
    date: '2017-05-03',
    name: 'Jerry',
    address: 'No. 189, Grove St, Los Angeles',
  },
  {
    date: '2016-05-02',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
])

const search = ()=>{
  tableData.value  =tableData.value.filter(v=>v.name.includes(input.value))
}

以上是查询方法实现的一种,还有另一种,就是新建一个reactive类型的变量,然后把tableData包裹起来。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/164782.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

java+mysql的校园兼职微信小程序(附源码 调试 文档)

校园兼职微信小程序 摘要一、引言二、国内外研究现状三、系统设计四、系统实现与界面展示五、源码获取 摘要 本文详述了一个基于Java和MySQL数据库技术的校园兼职微信小程序的毕业设计。系统主要分为三种用户角色&#xff1a;管理员、学生用户和商家用户。管理员拥有学生管理、…

Adversarially Robust Neural Architecture Search for Graph Neural Networks

Adversarially Robust Neural Architecture Search for Graph Neural Networks----《面向图神经网络的对抗鲁棒神经架构搜索》 摘要 图神经网络&#xff08;GNN&#xff09;在关系数据建模方面取得了巨大成功。尽管如此&#xff0c;它们仍然容易受到对抗性攻击&#xff0c;这对…

思维模型 留白效应

本系列文章 主要是 分享 思维模型 &#xff0c;涉及各个领域&#xff0c;重在提升认知。因留白而遐想。 1 留白效应的应用 1.1 留白效应在艺术领域的应用 欧洲的艺术和设计领域有很多经典的实际案例&#xff0c;其中荷兰画家文森特梵高的作品《星夜》是一幅非常著名的油画&am…

合并两个有序链表(冒泡排序实现)

实例要求&#xff1a;将两个升序链表合并为一个新的 升序 链表并返回&#xff1b;新链表是通过拼接给定的两个链表的所有节点组成的&#xff1b;实例分析&#xff1a;先拼接两个链表&#xff0c;在使用冒泡排序即可&#xff1b;示例代码&#xff1a; struct ListNode* mergeTwo…

EMD、EEMD、FEEMD、CEEMDAN分解的对比(其中CEEMDAN分解可以有效消除模态分解)

理论部分 EMD (Empirical Mode Decomposition)、EEMD (Ensemble EMD)、FEEMD (Fast Ensemble EMD) 和 CEEMDAN (Complete Ensemble EMD with Adaptive Noise) 是一些常用的信号分解方法&#xff0c;它们在信号分解的效果和特性上有所区别。 1. EMD&#xff1a; - EMD是最基础…

2023年【G1工业锅炉司炉】报名考试及G1工业锅炉司炉理论考试

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 G1工业锅炉司炉报名考试是安全生产模拟考试一点通生成的&#xff0c;G1工业锅炉司炉证模拟考试题库是根据G1工业锅炉司炉最新版教材汇编出G1工业锅炉司炉仿真模拟考试。2023年【G1工业锅炉司炉】报名考试及G1工业锅炉…

设计模式-行为型模式-策略模式

一、什么是策略模式 策略模式是一种行为设计模式&#xff0c;它允许在运行时选择算法或行为&#xff0c;并将其封装成独立的对象&#xff0c;使得这些算法或行为可以相互替换&#xff0c;而不影响使用它们的客户端。&#xff08;ChatGPT生成&#xff09; 主要组成部分&#xff…

数据结构与算法-图

图 &#x1f388;2.图的存储结构&#x1f4d6;2.4.2邻接表的存储✅2.4.2.1逆邻接表✅2.4.2.2邻接表存储结构的定义✅2.4.2.3邻接表存储结构的类定义✅2.4.2.4创建n个顶点m条边的无向网✅2.4.2.5创建n个顶点m条边的有向网✅2.4.2.6定位操作-查找定点信息在顶点数组中的下标✅2.4…

Spring Boot中使用Redis进行大数据缓存

Spring Boot中使用Redis进行大数据缓存 在Spring Boot中使用Redis进行大数据缓存是一种常见的做法&#xff0c;因为Redis是一种高性能的内存数据库&#xff0c;适用于缓存大量数据。以下是说明和示例代码&#xff0c;演示如何在Spring Boot项目中使用Redis进行大数据缓存。 步…

C语言基础篇4:变量、存储、库函数

1 局部变量和全局变量 在介绍局部变量和全局变量前&#xff0c;先了解一些关于作用域方面的内容。作用域的作用就是决定程序中的哪些语句是可用的&#xff0c;换句话说&#xff0c;就是程序中的可见性。作用域有局部作用域和全局作用域&#xff0c;那么局部变量就具有局部作用域…

3DMAX森林树木植物插件ForestPackLite教程

3DMAX森林树木植物插件ForestPackLite教程 Forest Pack是世界上最受欢迎的散布插件。它提供了一个完整的解决方案来创建大面积的物体&#xff0c;从树木和植物到建筑、人群、骨料、地面覆盖物、岩石等等。如果你能为它建模&#xff0c;森林包就能把它分散开来。 无数工作室依靠…

安装Nginx时报:./configure: error: can not define uint32_t

安装版本&#xff1a;v.1.25.3 安装命令&#xff1a; ./configure --prefix/opt/nginx/1.25.3 && make && make install 执行命令后出现异常&#xff0c;如图&#xff1a; 解决方法&#xff1a; yum install -y kernel-headers kernel-devel gcc make

算数通关村第十一关-白银挑战位运算高频题

位移的运算 位1的个数 描述 : 编写一个函数&#xff0c;输入是一个无符号整数&#xff08;以二进制串的形式&#xff09;&#xff0c;返回其二进制表达式中数字位数为 1 的个数&#xff08;也被称为汉明重量&#xff09;。 题目 : LeetCode 191.位1的个数 191. 位1的个数…

Java入门篇 之 抽象类接口

本篇碎碎念&#xff1a;个人认为压力是一种前进的动力&#xff0c;但是不要有太多压力&#xff0c;不然会使心情烦躁&#xff0c;会控制不住自己的情绪&#xff0c;会在一个临界值爆发&#xff0c;一旦爆发&#xff0c;将迟迟不能消散 今日份励志文案: 努力的背后必有加倍的赏赐…

配置VNC环境时,出现xauth: file /root/.Xauthority does not exist的解决方案。

问题描述 在配置VNC&#xff08;Virtual Network Computing&#xff09;环境的过程时&#xff0c;首先安装了tigervnc-server包。在使用&#xff1a; vncserver命令创建VNC会话号的时候出现了一个报错&#xff1a;xauth: file /root/.Xauthority does not exist 原因分析&…

大数据HCIE成神之路之数学(3)——概率论

概率论 1.1 概率论内容介绍1.1.1 概率论介绍1.1.2 实验介绍 1.2 概率论内容实现1.2.1 均值实现1.2.2 方差实现1.2.3 标准差实现1.2.4 协方差实现1.2.5 相关系数1.2.6 二项分布实现1.2.7 泊松分布实现1.2.8 正态分布1.2.9 指数分布1.2.10 中心极限定理的验证 1.1 概率论内容介绍…

Sql Server 2017主从配置之:发布订阅

使用发布订阅模式搭建Sql Server 2017主从同步&#xff0c;类似事件通知机制&#xff0c;基本可以做到准实时同步&#xff0c;可以同时做到一对多的数据同步。 不过发布订阅模式&#xff0c;只能同时数据&#xff0c;不能同步表结构。在创建发布的时候&#xff0c;需要选择需要…

Hive调优

1.参数配置优化 设定Hive参数有三种方式&#xff1a; &#xff08;1&#xff09;配置Hive文件 当修改配置Hive文件的设定后&#xff0c;对本机启动的所有Hive进程都有效&#xff0c;因此配置是全局性的。 一般地&#xff0c;Hive的配置文件包括两部分&#xff1a; a&#xff…

使用Spring Boot结合JustAuth实现支付宝、微信、微博扫码登录功能

使用Spring Boot结合JustAuth实现支付宝、微信、微博扫码登录功能 在使用Spring Boot结合JustAuth实现支付宝、微信、微博扫码登录功能之前&#xff0c;需要先确保已经配置好Spring Boot项目&#xff0c;并且添加了JustAuth的依赖。你可以在项目的pom.xml文件中添加如下依赖&a…

spass-二元变量相关分析

基础概念 计算相关系数r&#xff1a;利用样本数据计算样本相关系数&#xff0c;样本相关系数反映了两变量间线性相关程度的强弱。相关系数的取值范围界于-1与1之间&#xff0c;即-1≤r≤1 当0<r ≤ 1&#xff0c;表明变量之间存在正相关关系&#xff1b; 当-1 ≤ r…