Vue框架实现对前端数据表的增删改查(第六课)

news2025/7/30 18:51:56

前端对数据的增删改查你看到过吗?今天带你来实现一下在前端就页面上实现对数据的增伤改查

第一部分功能演示

先看下页面效果

 

  1.  增加一条数据

  1. 删除一条数据

 

  1. 修改一条数据

 

  1. 查询指定的一条记录

第二部分 上面的功能该如何实现的呢!首先又是页面改如何展示出来。

第一步 提前写好CSS样式

  <style>
        * {
            font-weight: 500;
            font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
        }

        table {
            border-collapse: collapse;
            margin: 0%;
        }

        th,
        td {
            border: 1px solid rgb(255, 0, 0);
            width: 100px;
            height: 40px;
            text-align: center;
        }

        fieldset {
            border-radius: 12px;
            background-color: rgb(188, 225, 240);
            color: black;
            box-shadow: 1px solid black;
        }

        th {
            background-color: rgb(255, 255, 255);
            color: rgb(255, 0, 0);
            font-weight: 900;
            text-align: center;
        }
    </style>

第二步 实现表格中V-for表头的信息打印

用户给出这个数据你能想到什么  数组

 

 

如果是数组我会这样去遍历

 

用户给出这个数据你能想到什么  对象

 

如果是对象我会这样去遍历

 

用户给出这个数据你能想到什么 数组 对象

 

第三步分析表格结构写出对应的模拟数据

                       Book: [
                        {
                            id: 1,
                            name: "《JavaScript从初级到中级在到高级》",
                            date: "2022年9月",
                            price: 34,
                            autor: "张三",
                            count: 1
                        },
                        {
                            id: 2,
                            name: "《java从入门到放弃》",
                            date: "2022年10月",
                            price: 79,
                            autor: "李四",
                            count: 1
                        },
                        {
                            id: 3,
                            name: "《Mysql数据库》",
                            date: "20021年3月",
                            price: 57,
                            autor: "赵武",
                            count: 1
                        },
                        {
                            id: 4,
                            name: "《我的世界》",
                            date: "20022年4月",
                            price: 17,
                            autor: "六二",
                            count: 1
                        },
                    ],
思考一下 我为什么能展示出来这些信息

第四步 将所有的模拟数据展示在控制台

为什么这样遍历可以出数据呢

 

  <tr v-for="(Book,index) in Book " :key="index.index+''">
                <td>{{index+1}}</td>
                <td>{{Book.name}}</td>
                <td>{{Book.date}}</td>
                <td>{{Book.price}}</td>
                <td>{{Book.autor}}</td>
                <td>
                    <button @click="reduce(Book.id)">-</button>
                    {{Book.count}}
                    <button @click="increase(Book.id)">+</button>
                </td>
                <td>
                    <button @click="remove(Book.id)">移除</button>
                </td>
                <td><input type="button" value="修改" v-on:click="shoeGoods(index)" /></td>
                <td> <button @click="addArray()">增加数据</button></td>
            </tr>

第五步 实现对表格中数据的删除一条记录功能

 

                     remove(id) {
                    this.Book.forEach(element => {
                        if (element.id == id) this.Book.splice(this.Book.indexOf(element), 1)
                    })
                },

第六步 实现对表格中数据增加一条记录的功能

 

                    addArray() {
                    alert("增加数据")
                    var bookones = { id: this.BookId, name: this.BookName, date: this.BookDate, price: this.BookPrice, autor: this.AuthorName }
                    this.Book.push(bookones)
                    this.BookId = this.BookName = this.BookDate = this.BookPrice = this.AuthorName = this.BookNum = ""
                    // console.log(this.$opion.data())
                    this.popShow = false; //窗口的显示
                },

第六步 实现对表格的数据中一条记录并且对数据进行修改

 <!-- 修改功能 -->
        <fieldset>
            <legend>修改用户的数据信息</legend>
            <div id="pop" v-show="popShow">
                修改的数据名称: <input type="text" v-model="names" />
                修改的数据日期:<input type="date" v-model="rundates" />
                修改的数据价格 <input type="text" v-model="prices" />
                修改的数据作者 <input type="text" v-model="author" />
                修改的数据数量 <input type="number" v-model="nums" />
                <button type="button" @click="getModify(index)">修改</button>
                <button type="button" @click="closeWindow">取消</button>
            </div>
        </fieldset>

 

第七步 实现对表格的数据的价格求出总和

 

第 八步 实现对表格的数据的关键记录的查询

                // 查询功能
                search(that) {
                    console.log(that);
                    return this.Book.filter(Book => {
                        if (Book.name.includes(that)) {
                            // 打印查询内容的信息
                            console.log(Book.id + "______" + Book.name + "______" + Book.date + "______" + Book.price + "______" + Book.autor + "______" + Book.count)
                            var a = Book.id;
                            var b = Book.name;
                            var c = Book.date;
                            var d = Book.price;
                            var e = Book.autor;
                            var f = Book.count;
                            var err = [a, b, c, d, e, f]
                            document.write("<h1>" + err + "</h1>")

                            return Book;
                        }
                        console.log(that)
                    })
                },

第三部分 部分代码块

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <script src="./js/vue.js"></script>
    <script>
        const app = Vue.createApp({
            data() {
                return {
                    searchStr: null,
                    popShow: false,
                    popShows: false,
                    names: null,
                    prices: null,
                    autols: null,
                    keys: "",
                    datas: null,
                    // 增加的数据
                    BookId: "",
                    BookName: "",
                    BookDate: "",
                    BookPrice: "",
                    BookNum: "",
                    AuthorName: "",
                    that: "",
                    // 创建表格的数组
                    ThBookNameArray: ["书籍编号", "书籍名称", "出版日期", "价格", "作者", "购买的数量", "移除数据", "修改数据", "增加数据"],
                    keywyrds: "",
                    sortype: "",
            },
        app.mount(".app")
    </script>
</body>

</html>

 本案例采用的知识点有  V-for  V-on   v-model 和对函数的综合使用 算是一个经典的案例吧!

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

吃豆人游戏-第12届蓝桥杯Scratch选拔赛真题精选

[导读]&#xff1a;超平老师计划推出Scratch蓝桥杯真题解析100讲&#xff0c;这是超平老师解读Scratch蓝桥真题系列的第79讲。 蓝桥杯选拔赛每一届都要举行4~5次&#xff0c;和省赛、国赛相比&#xff0c;题目要简单不少&#xff0c;再加上篇幅有限&#xff0c;因此我精挑细选…

基于PHP+MySQL的在线投票系统设计与实现

随着时代的发展,人们需要获取更多的信息和用户的意见,这时候就会产生一个投票。转托管模式都是人工发传单,然后填写来进行。但是随着互联网的发展,这种模式已经逐渐被淘汰,人们越来越希望通过更加方便快捷的方式来进行在线投票。这就是在线投票系统,这是我们设计本系统一个初衷…

传奇GOM/GEE微端配置外网架设教程

传奇GOM/GEE微端配置外网架设教程 我是艾西&#xff0c;经常听到一些小伙伴说微端需要购买&#xff1f;其实大家理解错了&#xff0c;传奇微端自己就可以搭建的是不需要购买的&#xff0c;如果是说单独架设到另外一台服务器上那么这才是需要收费的俗称微端服务器。主要用于跑带…

Nginx+keeplived高可用

目录 一、环境准备 1、准备3台centos服务器 2、安装软件 二、keepalived配置 三、nginx进程监视脚本 一、环境准备 1、准备3台centos服务器 服务器名主机名IPVIPNginx代理服务器proxy1192.168.1.10192.168.1.100Nginx代理服务器proxy2192.168.1.20web网站服务器web1192.…

TikTok 的 TAP好货分销服务商招募啦,最新入驻政策速来了解

众所周知&#xff0c;以抖音快手平台为主的内容电商对于国内来说已经司空见惯&#xff0c;内卷到极致&#xff0c;但是对于国外来说还是一个比较新奇的领域。 而海外版抖音 TikTok就成功实现了内容电商的出海&#xff0c;将电商直播带出国门&#xff0c;面向全世界。为了完善T…

【16-配置中心之Nacos的基本使用Nacos服务之命令空间、Nacos服务之配置组、Nacos服务之配置拆分】

一.知识回顾 【0.三高商城系统的专题专栏都帮你整理好了&#xff0c;请点击这里&#xff01;】 【1-系统架构演进过程】 【2-微服务系统架构需求】 【3-高性能、高并发、高可用的三高商城系统项目介绍】 【4-Linux云服务器上安装Docker】 【5-Docker安装部署MySQL和Redis服务】…

SpringBoot与mockito那点事

题目起的很像那么回事&#xff0c;但是这篇博客本身写的很简单。 我不想写说一堆概念&#xff0c;然后阐释各种概念是什么意思。我喜欢的是直接从例子出发。 package com.example.demo.controller;import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; impo…

操作系统的奋斗(一)

第1章 计算机系统概述1.1操作系统的基本概念1.1.1操作系统的概念1.1.2操作系统的特征&#xff08;1&#xff09;并发&#xff08;2&#xff09;共享&#xff08;3&#xff09;虚拟&#xff08;4&#xff09;异步1.1.3操作系统的目标和功能1.2操作系统发展史&#xff08;1&#…

微信公众号开发:网页授权

一、背景介绍 微信公众号网页授权&#xff0c;目的就是获取用户相关信息&#xff0c;实现自己的业务逻辑&#xff0c;最终于会得到的信息如下表格&#xff0c;本文对应的任务获取到openid即可满足业务需求&#xff0c;本文内容包括环境、操作步骤及相关内容比较详细&#xff0…

3D可视化工厂是如何实现的?

3D可视化工厂是数字孪生的一种方式&#xff0c;是基于智慧工厂现实场景进行虚拟的可视化工厂。 在传统工作模式下&#xff0c;许多工厂仍然存在着数据孤岛、生产过程缺乏监控及工作效率低等问题。如何进行工厂数字化的集中管理&#xff0c;寻求全新的数据驱动型业务解决方案&am…

5.python 列表切片双冒号[: :]和[:,j]

列表切片1.[::]2.[ :,j]3. [::]操作高阶用法1.[::] 适用于Python中的list(也就是数组)&#xff0c;也适用于numpy科学结构(array等)。 使用方法[start: end : step ]&#xff0c;也就是[ 起始下标 : 终止下标 : 间隔距离 ] 切片范围是&#xff1a; start < x < end,注…

iOS 优雅的定义一些全局常量和函数

我们常常使用 #define 来定义一些宏&#xff0c;全局使用。但是可以采用一些更优雅的方式来实现。 方式一&#xff1a;使用 extern 使用场景&#xff1a;工程内多处用到同一个常量。开发中便与管理某一个模块的全局变量&#xff0c;通常创建一个模块的配置文件&#xff0c;里面…

Qt构建时遇到error LNK2019: 无法解析的外部符号 __imp__glAlphaFunc@8,

在我的印象中如果是遇到无法解析的外部命令&#xff0c;无非就是两种情况 头文件定义了方法没有实现lib库没加 因为我这次写的软件我不确定缺失什么库&#xff0c;所以就先检查方法是否未实现&#xff0c;发现方法都实现了&#xff0c;那就只能是lib库缺失的问题了&#xff0…

【机器学习并行计算】1 MapReduce

1 MapReduce 每个节点计算梯度&#xff0c;然后汇聚到一台机子上&#xff0c;再进行梯度下降。时间还需要考虑通信时间。 通信的方式有两种&#xff1a;共享内存和消息传递&#xff1b;在这里存在多机的情况都是消息传递的方式。 通信耗时 MapReduce 会有风险&#xff0c;因为每…

[附源码]java毕业设计农村电商平台

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Python编程从入门到实践 第九章:类 练习答案记录

Python编程从入门到实践 第九章&#xff1a;类 练习答案记录 练习题导航Python编程从入门到实践 第九章&#xff1a;类 练习答案记录9.1 创建和使用类9.1.1 创建Dog类9.1.2 根据类创建实例练习9-1 餐馆 &#xff1a; 创建一个名为Restaurant 的类&#xff0c; 其方法__init__()…

Android 进程间通信(IPC机制)精炼详解

今天主要对 Android 中的跨进程通信进行总结下&#xff0c;先梳理下里面的涉及的一些概念 进程与线程 进程&#xff1a; 系统中正在运行的一个应用程序&#xff0c;某个程序一旦运行就是一个进程&#xff0c;是资源分配的最小单位&#xff1b;线程&#xff1a; 程序执行的最小…

曙光云使用说明

平台链接 https://ac.sugon.com/ac/home/index.html 控制台界面 创建个人工作目录及上传文件。点击概览页面顶端的 E-Shell 菜单栏&#xff0c;进入所连主机的 Shell 终端。在用户目录下新建个人工作目录&#xff0c;如&#xff1a;mkdir ywj2 安装MiniConda&#xff08;推荐…

Ubuntu20.04 如何开启root账户登陆

环境&#xff1a; 电脑&#xff1a;戴尔7080 系统&#xff1a;Windows 10 专业版 64位 VMware 16.0 &#xff1a;Ubuntu20.04 问题描述&#xff1a; Ubuntu20.04 如何开启root账户登陆 解决方案&#xff1a; 1.以普通用户登录系统&#xff0c;创建root用户的密码 在终端…

Java代码审计——WebGoat XSS

目录 &#xff08;一&#xff09;XSS 常见触发位置 1&#xff0e;JSP 表达式 2&#xff0e;EL &#xff08;二&#xff09;反射型 XSS (三&#xff09; 存储型 XSS &#xff08;四&#xff09;XSS 漏洞修复 配置过滤器&#xff1a; &#xff08;一&#xff09;XSS 常见触发…