蓝桥杯,利用 Vue.js 构建简易任务管理器

news2025/3/26 21:54:50

在日常开发中,我们经常需要处理各种任务和计划。一个简单且高效的任务管理器可以帮助我们更好地组织和安排时间。今天,我将向大家展示如何使用 Vue.js 构建一个简易的任务管理器。这个项目不仅能够帮助我们更好地理解 Vue.js 的基本语法和功能,还能为我们提供一个实用的小工具。

项目概述

这个任务管理器的主要功能包括:

  1. 添加任务:用户可以在输入框中输入任务内容,并点击“确认”按钮将其添加到任务列表中。

  2. 删除任务:用户可以点击任务旁边的“删除”按钮,将任务从列表中移除。

  3. 清空任务:用户可以点击“清除”按钮,将所有任务一次性清空。

  4. 显示任务总数:在任务列表下方显示当前任务的总数。

vue的在线cdn 

<script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>

HTML 结构

以下是 index.html 的代码:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>任务管理器</title>
    <link type="text/css" href="css/style.css" rel="stylesheet" />
  </head>
  <body>
    <div id="box">
      <div class="head">
        <h2>Todos</h2>
        <p>罗列日常计划,做一个时间管理大师!</p>
        <div class="input">
          <span>内容</span>
          <input type="text" placeholder="请输入你要做的事" />
          <span id="add" @click="add">确认</span>
        </div>
      </div>
      <ul class="list">
        <li v-if="data.length==0">暂无数据</li>
        <template v-else>
          <li v-for="(item, index) in data" :key="index">
            <span class="xh">{{ index + 1 }}</span>
            <span>{{ item }}</span>
            <span class="qc" @click="remove(index)"></span>
          </li>
          <li>
            <b>总数:{{ data.length }}</b>
            <b id="clear" @click="clear">清除</b>
          </li>
        </template>
      </ul>
    </div>
    <script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>
    <script>
      var top = new Vue({
        el: "#box",
        data() {
          return {
            data: ["吃", "喝"],
          };
        },
        methods: {
          remove(index) {
            this.data.splice(index, 1);
          },
          clear() {
            this.data = [];
          },
          add() {
            let inputVal = document.querySelector("input").value;
            this.data.push(inputVal);
          },
        },
      });
    </script>
  </body>
</html>

HTML 结构解析

  1. 头部区域

    • 包含一个标题 Todos 和一段描述文字,提示用户可以在这里罗列日常计划。

    • 一个输入框和一个“确认”按钮,用于添加新的任务。

  2. 任务列表区域

    • 使用 Vue.js 的 v-for 指令动态生成任务列表。

    • 每个任务项包含序号、任务内容和一个删除按钮。

    • 如果任务列表为空,则显示“暂无数据”。

    • 在任务列表的最后显示当前任务的总数和一个“清除”按钮。

 

Vue.js 逻辑实现

数据部分

JavaScript复制

data() {
  return {
    data: ["吃", "喝"],
  };
}
  • data 是一个数组,用于存储任务列表。初始值包含两个任务:“吃”和“喝”。

方法部分

  1. 添加任务

    JavaScript复制

    add() {
      let input = document.querySelector("input");
      let inputVal = input.value; // 获取输入框的值
      if (inputVal.trim() !== "") { // 检查输入是否为空
        this.data.push(inputVal); // 将值添加到任务列表
      }
      input.value = ""; // 清空输入框
    }
    • 获取输入框的值,并将其添加到 data 数组中。

  2. 删除任务

    JavaScript复制

    remove(index) {
      this.data.splice(index, 1);
    }
    • 使用 splice 方法从数组中移除指定索引的任务。

  3. 清空任务

    JavaScript复制

    clear() {
      this.data = [];
    }
    • data 数组清空,从而移除所有任务。

样式设计 

@charset "utf-8"; /* 设置字符编码为UTF-8,确保支持多种字符 */
/* 全局重置样式 */
* {
	padding: 0; /* 移除所有元素的内边距 */
	margin: 0; /* 移除所有元素的外边距 */
}

/* 列表样式重置 */
ul {
	list-style: none; /* 移除列表的默认样式(如圆点、数字等) */
}

/* 页面背景设置 */
body {
	background-color: #2d2d2d; /* 设置页面背景颜色为深灰色 */
}

/* 任务管理器容器样式 */
#box {
	width: 800px; /* 设置容器宽度 */
	margin: 50px auto; /* 上下外边距为50px,左右外边距自动,使容器水平居中 */
	background-color: #fff; /* 设置容器背景颜色为白色 */
	box-shadow: 0 0 10px #ccc; /* 添加阴影效果,增强立体感 */
	border-radius: 5px; /* 设置圆角边框 */
	overflow: hidden; /* 隐藏超出容器的内容 */
}

/* 容器头部样式 */
#box .head {
	background-color: #DFF0D8; /* 设置头部背景颜色为淡绿色 */
	padding: 20px; /* 添加内边距 */
}

/* 头部标题样式 */
#box .head h2 {
	color: #3C763D; /* 设置标题颜色为深绿色 */
}

/* 头部描述文字样式 */
#box .head p {
	font-size: 12px; /* 设置字体大小 */
	color: #3C763D; /* 设置字体颜色为深绿色 */
	line-height: 30px; /* 设置行高 */
}

/* 输入区域样式 */
#box .head .input {
	height: 30px; /* 设置高度 */
	line-height: 30px; /* 设置行高,使文字垂直居中 */
	border-radius: 5px; /* 设置圆角边框 */
	background-color: #EEEEEE; /* 设置背景颜色为浅灰色 */
	overflow: hidden; /* 隐藏超出区域 */
	border: 1px solid #ccc; /* 添加边框 */
}

/* 输入区域内的span样式 */
#box .head .input span {
	display: inline-block; /* 设置为行内块元素 */
	width: 50px; /* 设置宽度 */
	height: 30px; /* 设置高度 */
	text-align: center; /* 文字居中 */
	font-size: 12px; /* 设置字体大小 */
	float: left; /* 向左浮动 */
}

/* 输入框样式 */
#box .head .input input {
	float: left; /* 向左浮动 */
	width: calc(100% - 102px); /* 计算宽度,确保输入框占据剩余空间 */
	border: none; /* 移除边框 */
	outline: none; /* 移除焦点时的轮廓 */
	height: 30px; /* 设置高度 */
	text-indent: 20px; /* 设置文本缩进 */
}

/* 输入区域内的第一个span样式(内容提示) */
#box .head .input span:first-child {
	border-right: 1px solid #ccc; /* 添加右侧边框 */
}

/* 输入区域内的最后一个span样式(添加按钮) */
#box .head .input span:last-child {
	border-left: 1px solid #ccc; /* 添加左侧边框 */
	cursor: pointer; /* 设置鼠标指针为手型,表示可点击 */
}

/* 任务列表区域样式 */
#box .list {
	padding: 20px; /* 添加内边距 */
}

/* 任务列表项样式 */
#box .list li {
	border-bottom: 1px dashed #ccc; /* 添加底部虚线边框 */
	height: 40px; /* 设置高度 */
	font-size: 14px; /* 设置字体大小 */
	color: #2D2D2D; /* 设置字体颜色 */
}

/* 最后一个列表项样式 */
#box .list li:last-child {
	line-height: 40px; /* 设置行高 */
	border-bottom: none; /* 移除底部边框 */
	padding: 0 20px; /* 添加内边距 */
}

/* 列表项内的span样式 */
#box .list li span {
	float: left; /* 向左浮动 */
	height: 20px; /* 设置高度 */
	line-height: 20px; /* 设置行高 */
	margin: 10px 0; /* 设置上下外边距 */
	text-align: center; /* 文字居中 */
}

/* 列表项内的第一个span样式(序号) */
#box .list li span:first-child {
	width: 50px; /* 设置宽度 */
	border-right: 1px solid #ccc; /* 添加右侧边框 */
	margin-right: 10px; /* 设置右侧外边距 */
}

/* 列表项内的最后一个span样式(删除按钮) */
#box .list li span:last-child {
	width: 30px; /* 设置宽度 */
	background: url(../img/icon.png) no-repeat center center; /* 设置背景图片 */
	background-size: 50%; /* 设置背景图片大小 */
	float: right; /* 向右浮动 */
	margin-right: 20px; /* 设置右侧外边距 */
	cursor: pointer; /* 设置鼠标指针为手型 */
}

/* 最后一个列表项内的第一个b标签样式(总数提示) */
#box .list li:last-child b:first-child {
	float: left; /* 向左浮动 */
}

/* 最后一个列表项内的最后一个b标签样式(清除按钮) */
#box .list li:last-child b:last-child {
	float: right; /* 向右浮动 */
	cursor: pointer; /* 设置鼠标指针为手型 */
}
  1. 全局样式:重置了默认的 paddingmargin,并移除了列表的默认样式。

  2. 容器样式:设置了任务管理器容器的宽度、背景颜色、阴影和圆角,使其在页面中居中显示。

  3. 头部样式:设置了头部的背景颜色、内边距、标题和描述文字的样式。

  4. 输入区域样式:设计了输入框和按钮的布局,包括宽度计算、边框和浮动。

  5. 任务列表样式:定义了任务列表项的布局、边框、字体大小和颜色。

  6. 特殊样式:为序号、删除按钮、总数提示和清除按钮添加了特定的样式和交互效果。

总结

通过这个简单的任务管理器项目,我们学习了 Vue.js 的基本用法,包括数据绑定、事件处理和条件渲染等功能。这个项目虽然简单,但功能实用,可以作为我们日常任务管理的小工具。同时,它也为初学者提供了一个很好的学习和实践机会,帮助大家更好地理解和掌握 Vue.js 的开发技巧。

如果你对这个项目感兴趣,可以尝试自己动手实现,并根据自己的需求进行扩展和优化。例如,可以为任务添加优先级、设置完成状态、保存任务到本地存储等功能,让任务管理器更加完善和强大。

希望这篇文章对你有所帮助!如果你有任何问题或建议,欢迎在评论区留言交流。

 

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

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

相关文章

Elasticsearch + Docker:实现容器化部署指南

Elasticsearch是一款强大的分布式搜索和分析引擎&#xff0c;广泛应用于日志分析、全文检索、实时数据分析等场景。而Docker作为一种轻量级的容器化技术&#xff0c;能够帮助开发者快速部署和管理应用。将Elasticsearch与Docker结合&#xff0c;不仅可以简化部署流程&#xff0…

win32汇编环境,网络编程入门之十一

;win32汇编环境,网络编程入门之十一 ;在上一教程里&#xff0c;我们学习了如何读取大容量的网页内容&#xff0c;在这一教程里&#xff0c;我们学习一下如何在wininet或winhttp机制中提取网页中的超链接 ;>>>>>>>>>>>>>>>>>…

穿越之程序员周树人的狂人日记Part3__人机共生纪元

穿越之程序员周树人的狂人日记Part3__人机共生纪元 代码知识点&#xff1a;协程、内存管理、版本控制 故事一【协程陷阱】择偶标准的多核运算 故事二【内存泄漏】中产幻觉的垃圾回收 故事三【版本控制】人设仓库的强制推送 故事四【容器化生存】&#xff1a;员工生存之现状 静夜…

后端——AOP异步日志

需求分析 在SpringBoot系统中&#xff0c;一般会对访问系统的请求做日志记录的需求&#xff0c;确保系统的安全维护以及查看接口的调用情况&#xff0c;可以使用AOP对controller层的接口进行增强&#xff0c;作日志记录。日志保存在数据库当中&#xff0c;为了避免影响接口的响…

循环查询指定服务器开放端口(Python)

循环查询指定服务器开放端口列表 # Time : 2025/3/22 # Author : cookie # Desc :import socket import concurrent.futures from datetime import datetime# 设置目标IP和端口范围 target_ip input("请输入目标IP地址: ") start_port int(input("请输入…

【STM32】第一个工程的创建

目录 1、获取 KEIL5 安装包2、开始安装 KEIL52.1、 激活2.2、安装DFP库 3、工程创建4、搭建框架5、开始编写代码 1、获取 KEIL5 安装包 要想获得 KEIL5 的安装包&#xff0c;在百度里面搜索“KEIL5 下载”即可找到很多网友提供的下载文件&#xff0c;或者到 KEIL 的官网下载&a…

SpringBoot+策略模式+枚举类,优雅消除if-else

需求分析 公司做物联网系统的&#xff0c;使用nettry进行设备连接&#xff0c;对设备进行数据采集&#xff0c;根据设备的协议对数据进行解析&#xff0c;解析完成之后存放数据库&#xff0c;但是不同厂家的设备协议不同。公司系统使用了使用了函数式编程的去写了一个解析类&am…

前端框架学习路径与注意事项

学习前端框架是一个系统化的过程&#xff0c;需要结合理论、实践和工具链的综合掌握。以下是学习路径的关键方面和注意事项&#xff1a; 一、学习路径的核心方面 1. 基础概念与核心思想 组件化开发&#xff1a;理解组件的作用&#xff08;复用性、隔离性&#xff09;、组件通信…

Linux驱动开发-①platform平台②MISC字符驱动框架③input框架

Linux驱动开发-①platform平台②MISC字符驱动框架③input框架 一&#xff0c;platform1.1 platform框架&#xff08;设备树下&#xff09;1.2 platform框架&#xff08;配置设备函数&#xff09; 二&#xff0c;MISC字符驱动框架三&#xff0c;input框架 一&#xff0c;platfor…

【mysql】唯一性约束unique

文章目录 唯一性约束 1. 作用2. 关键字3. 特点4. 添加唯一约束5. 关于复合唯一约束 唯一性约束 1. 作用 用来限制某个字段/某列的值不能重复。 2. 关键字 UNIQUE3. 特点 同一个表可以有多个唯一约束。唯一约束可以是某一个列的值唯一&#xff0c;也可以多个列组合的值唯…

常见中间件漏洞:Jboss篇

CVE-2015-7501 环境搭建 cd vulhub-master/jboss/JMXInvokerServlet-deserialization docker-compose up -d 过程 访问网址&#xff0c;存在页面说明接口存在且存在反序列化漏洞 http://8.130.17.222:8080/invoker/JMXInvokerServlet 2.下载 ysoserial ⼯具进⾏漏洞利⽤…

2025年优化算法:龙卷风优化算法(Tornado optimizer with Coriolis force,TOC)

龙卷风优化算法&#xff08;Tornado optimizer with Coriolis force&#xff09;是发表在中科院二区期刊“ARTIFICIAL INTELLIGENCE REVIEW”&#xff08;IF&#xff1a;11.7&#xff09;的2025年智能优化算法 01.引言 当自然界的狂暴之力&#xff0c;化身数字世界的智慧引擎&…

3.24-3 接口测试断言

一.postman 断言 1.断言再test中 #状态码是否等于200 tests["Status code is 200"] responseCode.code 200; #断言响应时间小于200ms tests["Response time is less than 200ms"] responseTime < 200; #断言响应体包含内容 tests["Body…

DeepSeek面试——模型架构和主要创新点

本文将介绍DeepSeek的模型架构多头潜在注意力&#xff08;MLA&#xff09;技术&#xff0c;混合专家&#xff08;MoE&#xff09;架构&#xff0c; 无辅助损失负载均衡技术&#xff0c;多Token 预测&#xff08;MTP&#xff09;策略。 一、模型架构 DeepSeek-R1的基本架构沿用…

Python----计算机视觉处理(Opencv:图像亮度变换)

一、图像亮度变换 亮度调整&#xff1a;图像像素强度整体变高或者变低。 对比度调整&#xff1a;图像暗处像素强度变低&#xff0c;图像亮处像素强度变高&#xff0c;从而拉大中间某个区域范围的显示精 度。 A&#xff1a;原图 …

无人机动平衡-如何在螺旋桨上添加或移除材料

平衡无人机螺旋桨是一项精细的工作&#xff0c;直接影响飞行稳定性和组件寿命。不同的方法适用于不同的情况&#xff0c;螺旋桨的材料和尺寸以及所需调整的幅度都会影响选择的方法。 本文将深入探讨添加如胶水和胶带等材料的方法&#xff0c;以及通过打磨和修剪来移除质量的方…

基于python的租房网站-房屋出租租赁系统(python+django+vue)源码+运行步骤

该项目是基于python/django/vue开发的房屋租赁系统/租房平台&#xff0c;作为本学期的课程作业作品。欢迎大家提出宝贵建议。给师弟开发的课程作业&#xff0c;技术学习可以留言哦 功能介绍 平台采用B/S结构&#xff0c;后端采用主流的PythonDjango进行开发&#xff0c;前端采…

涨薪技术|k8s设计原理

01k8s介绍 Kubernetes 是一个可移植、可扩展的开源平台&#xff0c;用于管理容器化 工作负载和服务&#xff0c;有助于实现声明性配置和自动化。它有一个庞大、快速增长的生态系统。Kubernetes 服务、支持和工具广泛可用。Kubernetes 这个名字起源于希腊语&#xff0c;意思是舵…

基于FPGA的16QAM+帧同步系统verilog开发,包含testbench,高斯信道,误码统计,可设置SNR

目录 1.算法仿真效果 2.算法涉及理论知识概要 2.1 16QAM调制解调原理 2.2 帧同步 3.Verilog核心程序 4.完整算法代码文件获得 1.算法仿真效果 vivado2019.2仿真结果如下&#xff08;完整代码运行后无水印&#xff09;&#xff1a; 设置SNR12db 将FPGA数据导入到MATLAB显…

QuecPython 外设接口之GPIO应用指南

基础知识 了解GPIO基础知识更有益于我们使用它。 框图 GPIO&#xff08;通用输入输出&#xff09;是指一种通用的数字输入/输出接口&#xff0c;用于与外部电子元件或设备进行通信。它通常存在于微处理器、微控制器和其他嵌入式系统中。 物理电路结构如下图所示&#xff1a…