<h1>通讯录</h1> <button class="add-btn">添加联系人</button> <input type="text" id="search-input" placeholder="搜索姓名或电话"> <table> <thead> <tr> <th>姓名</th> <th>电话</th> <th>邮箱</th> <th>操作</th> </tr> </thead> <tbody id="contact-list"> <!-- 数据渲染 --> </tbody> </table> <!-- 分页按钮 --> <div id="page-buttons"></div> <!-- 弹出层,用于添加或编辑联系人 --> <div id="modal" class="modal" style="display: none;"> <div class="modal-content"> <span class="close">×</span> <form> <div class="form-group"> <label for="name">姓名</label> <input type="text" id="name" name="name" required> </div> <div class="form-group"> <label for="phone">电话</label> <input type="text" id="phone" name="phone" required> </div> <div class="form-group"> <label for="email">邮箱</label> <input type="text" id="email" name="email" required> </div> <button id="save-btn">保存</button> <button id="cancel-btn">取消</button> </form> </div> </div>帮我加入一个搜索框,通过搜索框的内容可以查找到查找的内容,让数据具有添加删除和编辑的功能,编辑的时候增加弹窗

时间: 2023-06-26 08:09:35 浏览: 50
好的,你需要在代码中添加以下功能: 1. 在搜索框上绑定一个事件监听器,当输入框中有内容输入时,筛选出匹配的联系人并进行渲染。 2. 在每个联系人的操作列中添加删除和编辑按钮,并为它们绑定事件监听器。 3. 当点击编辑按钮时,在弹出层中显示该联系人的信息,并将保存按钮改为更新按钮。 4. 当点击保存按钮时,将新的联系人信息保存到数据中并渲染页面。 5. 当点击更新按钮时,将编辑后的联系人信息更新到数据中并重新渲染页面。 下面是修改后的代码: ```html <h1>通讯录</h1> <button class="add-btn">添加联系人</button> <input type="text" id="search-input" placeholder="搜索姓名或电话"> <table> <thead> <tr> <th>姓名</th> <th>电话</th> <th>邮箱</th> <th>操作</th> </tr> </thead> <tbody id="contact-list"> <!-- 数据渲染 --> </tbody> </table> <!-- 分页按钮 --> <div id="page-buttons"></div> <!-- 弹出层,用于添加或编辑联系人 --> <div id="modal" class="modal" style="display: none;"> <div class="modal-content"> <span class="close">×</span> <form> <div class="form-group"> <label for="name">姓名</label> <input type="text" id="name" name="name" required> </div> <div class="form-group"> <label for="phone">电话</label> <input type="text" id="phone" name="phone" required> </div> <div class="form-group"> <label for="email">邮箱</label> <input type="text" id="email" name="email" required> </div> <button id="save-btn">保存</button> <button id="update-btn" style="display: none;">更新</button> <button id="cancel-btn">取消</button> </form> </div> </div> <script> // 数据 let contacts = [ { name: "张三", phone: "13456789012", email: "zhangsan@example.com" }, { name: "李四", phone: "15678901234", email: "lisi@example.com" }, { name: "王五", phone: "18901234567", email: "wangwu@example.com" }, { name: "赵六", phone: "13245678901", email: "zhaoliu@example.com" }, { name: "钱七", phone: "17509876543", email: "qianqi@example.com" } ]; // 渲染联系人列表 function renderContacts(contacts) { const tbody = document.getElementById("contact-list"); tbody.innerHTML = ""; contacts.forEach((contact, index) => { const tr = document.createElement("tr"); tr.innerHTML = ` <td>${contact.name}</td> <td>${contact.phone}</td> <td>${contact.email}</td> <td> <button class="delete-btn" data-index="${index}">删除</button> <button class="edit-btn" data-index="${index}">编辑</button> </td> `; tbody.appendChild(tr); }); } // 添加联系人 function addContact(contact) { contacts.push(contact); renderContacts(contacts); } // 删除联系人 function deleteContact(index) { contacts.splice(index, 1); renderContacts(contacts); } // 编辑联系人 function editContact(index) { const contact = contacts[index]; document.getElementById("name").value = contact.name; document.getElementById("phone").value = contact.phone; document.getElementById("email").value = contact.email; document.getElementById("save-btn").style.display = "none"; document.getElementById("update-btn").style.display = "inline-block"; document.getElementById("modal").style.display = "block"; document.getElementById("update-btn").addEventListener("click", () => { updateContact(index); }); } // 更新联系人 function updateContact(index) { contacts[index].name = document.getElementById("name").value; contacts[index].phone = document.getElementById("phone").value; contacts[index].email = document.getElementById("email").value; document.getElementById("modal").style.display = "none"; document.getElementById("update-btn").removeEventListener("click", updateContact); renderContacts(contacts); } // 绑定事件监听器 document.querySelector(".add-btn").addEventListener("click", () => { document.getElementById("name").value = ""; document.getElementById("phone").value = ""; document.getElementById("email").value = ""; document.getElementById("save-btn").style.display = "inline-block"; document.getElementById("update-btn").style.display = "none"; document.getElementById("modal").style.display = "block"; }); document.querySelector(".close").addEventListener("click", () => { document.getElementById("modal").style.display = "none"; }); document.querySelector("#cancel-btn").addEventListener("click", () => { document.getElementById("modal").style.display = "none"; }); document.getElementById("save-btn").addEventListener("click", (event) => { event.preventDefault(); const contact = { name: document.getElementById("name").value, phone: document.getElementById("phone").value, email: document.getElementById("email").value }; addContact(contact); document.getElementById("modal").style.display = "none"; }); document.getElementById("search-input").addEventListener("input", () => { const keyword = document.getElementById("search-input").value.trim(); const filteredContacts = contacts.filter((contact) => { return contact.name.includes(keyword) || contact.phone.includes(keyword); }); renderContacts(filteredContacts); }); document.getElementById("contact-list").addEventListener("click", (event) => { const target = event.target; if (target.classList.contains("delete-btn")) { deleteContact(target.getAttribute("data-index")); } else if (target.classList.contains("edit-btn")) { editContact(target.getAttribute("data-index")); } }); // 初始化 renderContacts(contacts); </script> ```

相关推荐

最新推荐

recommend-type

组成原理课程实验:MIPS 流水线CPU、实现36条指令、转发、冒险检测-内含源码和说明书.zip

组成原理课程实验:MIPS 流水线CPU、实现36条指令、转发、冒险检测-内含源码和说明书.zip
recommend-type

setuptools-50.0.2-py3-none-any.whl

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

setuptools-1.1.6.tar.gz

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

CEA二次开发脚本:用于ECSP配比设计

CEA二次开发脚本:用于ECSP配比设计
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依