学习尚硅谷Vue的TodoList案例下半部分总结

2024-01-07 06:44

本文主要是介绍学习尚硅谷Vue的TodoList案例下半部分总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天学习尚硅谷Vue的TodoList案例四到八节的内容,主要实现的功能有勾选、删除、底部统计、底部交互这几部分。先说勾选,想要获取到用户是否勾选,就要给checkbox多选框注册鼠标点击事件,这里的思路是用户虽然是获取到了是否勾选但还要知道勾选的是哪个事项,这时就要拿到事项对应的id,然后通过数组forEach方法遍历已有的事项做一个if判断里面的id和用户点击的事项的id直到一致之后就将事项里面的勾选值更改,即可实现页面和数据都是一致的了,以上的操作其实是在item组件中使用了App组件的方法,这里需要注意的是以现在的知识量想要子组件用到父组件身上的方法,就需要通过将父组件的方法写成函数的形式引入到子组件内让其接收,子组件调用的时候还可以传参会给父组件身上的函数做处理,但后面会学到更好方法来解决这个问题,在实现这个功能的同时也引出了v-mode双向数据绑定改变props数据的情况,我们之前学过props引入进来的数据只能读取不能修改,但这里却可以将它修改,通过测试发现Vue只能监测到我们修改整个对象(也就是内存的地址),但监测不到我们修改对象里面的值,虽然是可以这么改掉props的数据但是不提倡这么做。

下一个要实现的是删除功能,这个和勾选功能很相似,同样是给删除按钮绑定点击事件,触发事件先去获取事项的id,然后在App文件中通过数组的filter方法将删除的id事项过滤掉,使用filter这个方法Vue是可以检测到你改变了数组的,这时它就会帮我们重新渲染一般就可以达到数据和页面都删除的功能了。

最后要实现的就是底部的部分了,统计这里就比较直接,全部事项的总数就是数组的长度,但已完成的事项数量可以用不同的方法实现,首先是用数组的forEach方法实现,在方法外面先定义一个i变量作为已完成事项的计数,将事项的done勾选值作为判断条件,勾选则i++,最后得到已完成的事项总数,另一种是数组的reduce方法,这个方法需要传入两个参数,第一个参数是一个函数,第二个参数是初始值,这里的初始值是作为计数的起点,重点是第一个参数的函数,这个函数同样可以接收两个参数,第一个参数就是刚才的初始值,而第二个参数是数组的元素,有了元素我们就可以对它进行判断,判断条件成立的话就在return初始值加一,以此类推最后就得出了满足条件的事项。统计作为之后剩下最后一个就是清楚已完成的任务功能,因为这个功能比较特殊,事项如果全选的话那边底部的选项框也要自动勾选上,还有一种就是点击底部选项框时上面的事项全部都要勾选或取消,考虑到这是双向的情况下我们最好使用v-model双向数据绑定的形式来实现,这样两边都可以读取或修改v-model的数据了,有了这个思路之后实现该功能就变得简单明了了。

这篇关于学习尚硅谷Vue的TodoList案例下半部分总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/579047

相关文章

在Java中实现线程之间的数据共享的几种方式总结

《在Java中实现线程之间的数据共享的几种方式总结》在Java中实现线程间数据共享是并发编程的核心需求,但需要谨慎处理同步问题以避免竞态条件,本文通过代码示例给大家介绍了几种主要实现方式及其最佳实践,... 目录1. 共享变量与同步机制2. 轻量级通信机制3. 线程安全容器4. 线程局部变量(ThreadL

RabbitMQ消费端单线程与多线程案例讲解

《RabbitMQ消费端单线程与多线程案例讲解》文章解析RabbitMQ消费端单线程与多线程处理机制,说明concurrency控制消费者数量,max-concurrency控制最大线程数,prefe... 目录 一、基础概念详细解释:举个例子:✅ 单消费者 + 单线程消费❌ 单消费者 + 多线程消费❌ 多

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提