【JavaScript】3.1 项目实践:制作一个简单的网页应用

news2024/9/20 16:17:00

文章目录

    • 项目需求
    • HTML结构
    • JavaScript逻辑
      • 添加待办事项
      • 标记待办事项
      • 删除待办事项
      • 保存待办事项
    • 总结

在此章节中,我们将学习如何使用JavaScript创建一个简单的网页应用。这将是一个待办事项列表应用,用户可以添加新的待办事项,标记已完成的事项,以及删除事项。通过这个项目,我们将学习如何使用JavaScript操作DOM,处理事件,以及使用localStorage进行数据存储。

项目需求

我们的待办事项列表应用需要满足以下需求:

  1. 用户可以在输入框中输入待办事项,然后点击添加按钮,将待办事项添加到列表中。
  2. 用户可以点击待办事项旁边的复选框,将待办事项标记为已完成。
  3. 用户可以点击待办事项旁边的删除按钮,将待办事项从列表中删除。
  4. 用户关闭浏览器后,待办事项列表的状态应该被保存下来,用户再次打开浏览器时,应该能看到之前的待办事项。

HTML结构

首先,我们需要创建HTML页面的基本结构。我们需要一个输入框,一个添加按钮,以及一个待办事项列表。

<!DOCTYPE html>
<html>
<head>
  <title>Todo List</title>
</head>
<body>
  <input id="todoInput" type="text" placeholder="What needs to be done?">
  <button id="addButton">Add</button>
  <ul id="todoList"></ul>
  <script src="app.js"></script>
</body>
</html>

在这个HTML文件中,我们有一个input元素用于输入待办事项,一个button元素用于添加待办事项,以及一个ul元素用于显示待办事项列表。我们还包含了一个外部的JavaScript文件app.js,这个文件将包含我们的应用逻辑。

JavaScript逻辑

接下来,我们需要编写JavaScript代码来实现应用的逻辑。我们首先需要获取HTML元素的引用,然后对这些元素进行操作。

var todoInput = document.getElementById('todoInput');
var addButton = document.getElementById('addButton');
var todoList = document.getElementById('todoList');

添加待办事项

我们需要监听添加按钮的点击事件。当点击事件发生时,我们创建一个新的待办事项,并添加到列表中。

addButton.addEventListener('click', function() {
  var todoText = todoInput.value; // 获取待办事项的文本
  todoInput.value = ''; // 清空输入框

  var todoItem = document.createElement('li'); // 创建一个新的li元素
  todoItem.textContent = todoText; // 设置li元素的文本

  var checkbox = document.createElement('input'); // 创建一个新的input元素
  checkbox.type = 'checkbox'; // 设置input元素的类型为checkbox
  todoItem.prepend(checkbox); // 将checkbox添加到li元素的前面

  var deleteButton = document.createElement('button'); // 创建一个新的button元素
  deleteButton.textContent = 'Delete'; // 设置button元素的文本
  todoItem.append(deleteButton); // 将button添加到li元素的后面

  todoList.append(todoItem); // 将li元素添加到列表中
});

在这个代码中,我们首先获取待办事项的文本,然后清空输入框。然后,我们创建一个新的li元素,并设置其文本。我们还创建了一个复选框和一个删除按钮,并添加到li元素中。最后,我们将li元素添加到列表中。

标记待办事项

我们需要监听复选框的点击事件。当点击事件发生时,我们将待办事项标记为已完成。

todoList.addEventListener('change', function(event) {
  if (event.target.type === 'checkbox') {
    var checkbox = event.target;
    var todoItem = checkbox.parentElement;
    todoItem.style.textDecoration = checkbox.checked ? 'line-through' : 'none';
  }
});

在这个代码中,我们监听了列表的change事件。当复选框的状态改变时,change事件会被触发。我们检查事件的目标是否是复选框,如果是,我们获取复选框和其父元素(即li元素),然后根据复选框的状态来修改li元素的样式。

删除待办事项

我们需要监听删除按钮的点击事件。当点击事件发生时,我们将待办事项从列表中删除。

todoList.addEventListener('click', function(event) {
  if (event.target.tagName === 'BUTTON') {
    var button = event.target;
    var todoItem = button.parentElement;
    todoList.removeChild(todoItem);
  }
});

在这个代码中,我们监听了列表的click事件。当删除按钮被点击时,click事件会被触发。我们检查事件的目标是否是按钮,如果是,我们获取按钮和其父元素(即li元素),然后从列表中删除li元素。

保存待办事项

我们需要使用localStorage来保存待办事项的状态。当添加、标记或删除待办事项时,我们需要更新localStorage。

首先,我们需要在页面加载时,从localStorage中读取待办事项的状态,并更新列表。

window.addEventListener('load', function() {
  var todos = JSON.parse(localStorage.getItem('todos')) || [];
  for (var i = 0; i < todos.length; i++) {
    var todo = todos[i];
    createTodoItem(todo.text, todo.completed);
  }
});

在这个代码中,我们监听了load事件。当页面加载时,我们从localStorage中读取待办事项的状态,然后用这些状态来创建待办事项。

然后,我们需要在添加、标记或删除待办事项时,更新localStorage。

function updateLocalStorage() {
  var todos = [];
  var todoItems = todoList.children;
  for (var i = 0; i < todoItems.length; i++) {
    var todoItem = todoItems[i];
    var text = todoItem.textContent;
    var completed = todoItem.querySelector('input').checked;
    todos.push({ text: text, completed: completed });
  }
  localStorage.setItem('todos', JSON.stringify(todos));
}

在这个函数中,我们遍历待办事项列表,然后将每个待办事项的文本和完成状态保存到一个数组中。然后,我们将这个数组转换为JSON字符串,并保存到localStorage中。

我们需要在添加、标记或删除待办事项的事件处理函数中,调用这个函数。

addButton.addEventListener('click', function() {
  // ...
  updateLocalStorage();
});

todoList.addEventListener('change', function(event) {
  // ...
  updateLocalStorage();
});

todoList.addEventListener('click', function(event) {
  // ...
  updateLocalStorage();
});

总结

通过这个项目,我们学习了如何使用JavaScript来创建一个简单的网页应用。我们学习了如何操作DOM,处理事件,以及使用localStorage进行数据存储。这是一个很好的实践项目,通过它我们可以更好地理解和应用JavaScript的基本概念。

在接下来的章节中,我们将深入学习更多关于JavaScript的知识。希望你在学习的过程中能够找到乐趣,并且通过学习JavaScript,开启你的编程之旅!
在这里插入图片描述

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

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

相关文章

【C++学习手札】模拟实现list

​ &#x1f3ac;慕斯主页&#xff1a;修仙—别有洞天 ♈️今日夜电波&#xff1a;リナリア—まるりとりゅうが 0:36━━━━━━️&#x1f49f;──────── 3:51 &#x1f504; ◀️ ⏸ ▶️…

深入理解计算机系统(原书第三版)PDF 高清中文版

深入理解计算机系统 PDF 深入理解计算机系统 pdf&#xff0c; 这本书的全名是&#xff1a;Computer Systems&#xff1a;A Programmer’s Perspective&#xff08;所以它又被称为 CSAPP&#xff09;&#xff0c;个人习惯把它翻译为程序员所需了解的计算机系统知识&#xff0c;尽…

基于GPRS的汽车碰撞自动报警系统(论文+源码)

1. 系统设计 本次基于GPRS的汽车碰撞自动报警系统的设计中&#xff0c;其主要的目标功能如下&#xff1a;1、实时检测当前的GPS精度和纬度坐标&#xff1b;2.当发生碰撞后系统自动将当前的信息通过GPRS数据发送到远端数据进行报警&#xff1b;3、系统在碰撞后一方面进行本地报警…

运放如何进行全波整流

对于一个双极性的交流信号&#xff0c;如果想要把负半轴的信号镜像到正半轴&#xff0c;我们可以接一个整流桥&#xff0c;这种叫做全波整流。 如果双极性的交流信号经过一个二极管&#xff0c;则交流信号的负半轴不能通过二极管&#xff0c;输出只有正半轴的信号&#xff0c;这…

【UE5】五大基类及其使用

UObject UObject表示对象&#xff0c;准确来说&#xff0c;虚幻引擎中的对象基础类为UObject UObject提供了以下功能&#xff1a; 垃圾收集&#xff08;Garbage collection&#xff09;引用自动更新&#xff08;Reference updating&#xff09;反射&#xff08;Reflection&am…

【面试送分题!“商品分类浏览”如何测试?】

电商项目无论是工作中&#xff0c;还是面试中&#xff0c;都是一个高频出现的词。 面试官非常热衷提问关于电商项目的问题。例如商品分类怎么测试&#xff1f;购物车怎么测试&#xff1f;订单怎么测试&#xff1f;优惠券怎么测试&#xff1f;支付怎么测试&#xff1f;等等。 …

多功能回馈式交流电子负载的应用

多功能回馈式交流电子负载是用于模拟和测试电源、电池等电子设备的负载工具。它具有多种应用&#xff0c;可以用于测试和评估各种类型的电源&#xff0c;包括直流电源和交流电源。它可以模拟各种负载条件&#xff0c;如恒定电流、恒定电压和恒定功率&#xff0c;以验证电源的性…

ubuntu22.04 git 安装

安装git&#xff1a;默认情况下&#xff0c;Git 在 ubuntu 22.04 基础存储库中可用。 现在运行以下命令在您的 Ubuntu 系统上安装最新版本的 Git&#xff1a; 查看当前版本号 git --version

第五天 用Python批量处理Excel文件,实现自动化办公

用Python批量处理Excel文件&#xff0c;实现自动化办公 一、具体需求 有以下N个表&#xff0c;每个表的结构一样&#xff0c;如下&#xff1a; 需要把所有表数据汇总&#xff0c;把每个人的得分、积分分别加起来&#xff0c;然后按总积分排名&#xff0c;总积分一致时&#xff…

leedcode 刷题 - 除自身以外数组的乘积 - 和为 K 的子数组

I238. 除自身以外数组的乘积 - 力扣&#xff08;LeetCode&#xff09; 给你一个整数数组 nums&#xff0c;返回 数组 answer &#xff0c;其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在…

化学气相沉积(CVD)中的TEOS

在半导体制程中&#xff0c;薄膜的沉积是核心的步骤之一&#xff0c;有接触过CVD的小伙伴应该或多或少听过TEOS这种物质&#xff0c;TEOS作为一种重要的沉积源&#xff0c;尤其在低温氧化硅的生成过程中&#xff0c;发挥了无可替代的角色。今天我们就来聊聊这种物质。 什么是TE…

java SpringCloud版本b2b2c鸿鹄云商平台全套解决方案 小程序商城免费搭建

使用技术&#xff1a; Spring CloudSpring BootMybatis微服务服务监控可视化运营 B2B2C平台&#xff1a; 平台管理端(包含自营) 商家平台端(多商户入驻) PC买家端、手机wap/公众号买家端 微服务&#xff08;30个通用微服务如&#xff1a;商品、订单、购物车、个人中心、支…

Microsoft Office 2019下载工具

今天博主继续推出重磅福利——Microsoft Office合集的安装工具。 Microsoft Office是一套由微软公司开发的办公软件&#xff0c;它为 Microsoft Windows 和 Mac OS X而开发。与办公室应用程序一样&#xff0c;它包括联合的服务器和基于互联网的服务。最近版本的 Office 被称为 …

【MySQL】mysql中不推荐使用uuid或者雪花id作为主键的原因以及差异化对比

文章目录 前言什么是UUID?什么是雪花ID?什么是MySql自增ID?优缺点对比UUID:优点1.全球唯一性2.无需数据库支持 缺点1.存储空间大2.索引效率低3.查询效率低 雪花ID&#xff1a;优点1.分布式环境下唯一性 缺点1.依赖于机器时钟2.存储空间较大3.查询效率低 MYSQL自增:优点1.简单…

聚类算法模型的概念、评估及应用

聚类是一种无监督学习方法&#xff0c;其目标是将数据集中的样本分成不同的组别&#xff0c;使得同一组内的样本相似度较高&#xff0c;而不同组之间的样本相似度较低。聚类算法模型通常通过计算样本之间的相似度或距离来实现这一目标。以下是聚类算法模型的概念、评估及应用的…

电脑技巧:推荐八个非常实用的在线网站值得收藏

目录 1、wikihow 干货分享网站 2、次元小镇 二次元必备网站 3、AI创作家 4、SKRbt 搜索引擎网站 5、barbg 全球资源网站 6、书签地球 7、4KHDR世界 8、a real me 今天小编给大家推荐八个非常实用的在线网站值得收藏&#xff01; 1、wikihow 干货分享网站 这个网站是一…

文章解读与仿真程序复现思路——电工技术学报EI\CSCD\北大核心《面向差异化电源成本结构的容量市场机制设计》

这个文章标题涉及到容量市场机制设计&#xff0c;着重考虑了电源成本结构的差异性。下面对标题中的关键词进行解读&#xff1a; 面向&#xff08;Facing&#xff09;&#xff1a; 表示该容量市场机制设计是以某种方向、取向或目标为基础的。在这里&#xff0c;可能指的是设计是…

九州未来联合联通智网科技发布白皮书,促进车联网融合发展

2023年11月21日&#xff0c;由2023中国5G工业互联网大会组委会、工业和信息化部主办&#xff0c;联通智网科技承办的2023中国5G工业互联网大会——5G车联网与智慧交通创新发展平行会议&#xff0c;在武汉成功举办。 九州未来作为中国联通车联网创新联合体成员单位&#xff0c;受…

自学编程,用好这几个网站就够了!

如果你要自学编程&#xff0c;一定要收藏好这7个网站&#xff0c;上面免费的优质教程很多&#xff0c;完全可以省去你上万块钱的学费&#xff01; 话不多说&#xff0c;直接上干货&#xff01; 第一个&#xff0c;W3school 一个主打图文教程的网站&#xff0c;不管是前端开发…

域控操作五:统一熄屏睡眠时间

直接看图路径&#xff0c;我只设置了熄屏&#xff0c;如果要睡眠就下面那个启用设置时间