当前位置: 首页 > article >正文

JavaScript中todolist操作--待办事项的添加 删除 完成功能

效果图

在文本框中输入内容点击添加按钮会在下面生成

添加功能

html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="js/todolist.js" defer></script>
    <style>
       * {
            padding: 0;
            margin: 0;
        }
        
        .container {
            width: 25%;
            margin: 100px auto;
            min-width: 260px;
        }
        
        .container>div {
            display: flex;
            margin-bottom: 10px;
        }
        
        .container>div .content {
            width: 85%;
            /* 外轮廓去掉 */
            outline: none;
            padding: 3px 10px;
            border: 2px solid rgb(165, 41, 31);
            border-radius: 6px 0 0 6px;
        }
        
        .container>div .add {
            width: 15%;
            padding: 3px;
            background: rgb(165, 41, 31);
            color: #fff;
            border: none;
            border-radius: 0 6px 6px 0;
            cursor: pointer;
        }
        
        table {
            width: 100%;
            text-align: center;
            border-collapse: collapse;
            border: #fff 2px solid;
        }
        
        table thead tr {
            background: rgb(165, 41, 31);
            color: #fff;
        }
        
        table thead tr th {
            padding: 4px;
            font-size: 14px;
        }
        
        table tbody tr {
            background: #ddd;
            font-size: 13px;
        }
        
        table tbody tr:nth-child(even) {
            background: #eee;
        }
        
        table tbody tr td {
            padding: 4px;
        }
        table tbody tr input {
            border: 1px solid rgb(165, 41, 31);
            background: none;
            color: rgb(165, 41, 31);
            font-size: 12px;
            padding: 2px 5px;
            cursor: pointer;
            border-radius: 4px;
        }
        
        table tbody tr input:hover {
            box-shadow: 2px 2px 2px rgb(165, 41, 31);
        }

    </style>
</head>
<body>
    <div class="container">
        <div>
            <input type="text" class="content">
            <input type="button" value="添加" class="add">
        </div>
        <table border="1">
            <thead>
                <tr>
                    <th>待办事项</th>
                    <th>操作</th>
                </tr>
            </thead>
            <tbody>
                
            </tbody>
        </table>
    </div>
</body>
</html>

js

//增加
var arr=document.querySelector(".add")
var content=document.querySelector(".content")
var tbody=document.querySelector("tbody")
arr.onclick=function()
{   
    //trim()去掉字符串前后空格  防止全输入空格也会添加
    if(content.value.trim())
    {
    var tr=document.createElement("tr")
    var td1=document.createElement("td")
    var td2=document.createElement("td")

    td1.innerText=content.value
    td2.innerHTML='<input type="button" value="删除"><input type="button" value="修改"><input type="button" value="完成">'
    tr.appendChild(td1)
    tr.appendChild(td2)
    //添加元素要用父级元素添加子级元素
    tbody.appendChild(tr)
    content.value=""//添加之后文本框变为空
    }
}

 完成功能

点击完成之后事项加中划线 颜色变灰

注意这个功能要写在添加里面

删除 修改等功能同理

因为只有实现添加之后才会出现按钮

//增加
var arr=document.querySelector(".add")
var content=document.querySelector(".content")
var tbody=document.querySelector("tbody")
arr.onclick=function()
{   
    //trim()去掉字符串前后空格  防止全输入空格也会添加
    if(content.value.trim())
    {
    var tr=document.createElement("tr")
    var td1=document.createElement("td")
    var td2=document.createElement("td")

    td1.innerText=content.value
    td2.innerHTML='<input type="button" value="删除"><input type="button" value="修改"><input type="button" class="finish" value="完成">'
    tr.appendChild(td1)
    tr.appendChild(td2)

    tbody.appendChild(tr)
    content.value=""
    }
    var finish=document.getElementsByClassName("finish")
    //找到完成这个按钮以绑定事件
    for(var j=0;j<finish.length;j++)
    {
        finish[j].onclick=function()
        {
            var target=this.parentElement.previousElementSibling
            //this是一个按钮 父级是td 父级的前一个也是td 就是输入的内容
            target.style.color="#999" 
            target.style.textDocration="line-through"
        }
    }
}

对完成功能的改善 增加合理性

 var finish=document.getElementsByClassName("finish")
    for(var j=0;j<finish.length;j++)
    {
        finish[j].onclick=function()
        {   
            
            var target=this.parentElement.previousElementSibling
            
            if(target.style.textDocration=="line-through")
            {   
                this.value="完成"
                target.style.color="#000" 
            target.style.textDocration="none"
            }
            else
            {   
                this.value="撤销"
                target.style.color="#999" 
                 target.style.textDocration="line-through"
            }
            console.log(target.style.textDocration)
        }
    }

 

删除功能

 //删除
    var deletes=document.getElementsByClassName("delete")

    for(var k=0;k<deletes.length;k++)
    {
        deletes[k].onclick=function()
        {   
            //如果是完成的才能删  未完成不能删
            if(this.parentElement.previousElementSibling.style.textDocration=="line-through")
            {
                tbody.removeChild(this.parentElement.parentElement)
            }
            else
            {
                alert("继续努力吧")
            }
            //点击这个按钮的父级是三个按钮被包含的td 再父级是tr
            //tr包含三个按钮和待办事项的值 所以要把整个tr删了
            //找到tr的父级tbody调用方法就可以删除
        }
    }

修改功能

 //查找修改按钮
    var update = document.getElementsByClassName("update")
    for (var j = 0; j < update.length; j++) {
        //回显
        update[j].onclick = function() {
            var target = this.parentElement.previousElementSibling
                //如果该事项已经完成,则不做修改
            if (target.style.textDecoration == "line-through") {
                alert("事情已经完成,无需修改")
            } else {
                content.value = target.innerText
                add.value = "修改"
                flag = 1
                num = target.getAttribute("index")
            }
        }
   if (flag == 1) {
        var tds = document.querySelectorAll("tbody tr td:nth-child(1)")
        for (var j = 0; j < tds.length; j++) {
            if (tds[j].getAttribute("index") == num) {
                // 相等则进行修改
                tds[j].innerText = content.value

                content.value = ""
                add.value = "添加"
                flag = 0
            }
        }
        return
    }

全部代码

var add = document.querySelector(".add")
var content = document.querySelector(".content")
var tbody = document.querySelector("tbody")
    //标志变量  0添加 1修改
var flag = 0
var index = 0
    //记录当前被修改的是哪条信息
var num

add.onclick = function() {


    //修改
    if (flag == 1) {
        var tds = document.querySelectorAll("tbody tr td:nth-child(1)")
        for (var j = 0; j < tds.length; j++) {
            if (tds[j].getAttribute("index") == num) {
                // 相等则进行修改
                tds[j].innerText = content.value

                content.value = ""
                add.value = "添加"
                flag = 0
            }
        }
        return
    }


    // trim()去掉字符串前后的空格
    //添加
    if (content.value.trim()) {
        var tr = document.createElement("tr")
        var td1 = document.createElement("td")
            //给单元格绑定属性
        td1.setAttribute("index", index)
        index++

        var td2 = document.createElement("td")
        td1.innerText = content.value
        td2.innerHTML = '<input type="button" value="删除" class="delete"> <input type="button" value="修改" class="update"> <input type="button" value="完成" class="finish">'
        tr.appendChild(td1)
        tr.appendChild(td2)
        tbody.appendChild(tr)
        content.value = ""
    }



    //查找完成按钮
    var finish = document.getElementsByClassName("finish")
    for (var j = 0; j < finish.length; j++) {
        finish[j].onclick = function() {
            var target = this.parentElement.previousElementSibling
            if (target.style.textDecoration == "line-through") {
                target.style.color = "#000"
                target.style.textDecoration = "none"
                this.value = "完成"

            } else {
                this.value = "撤销"
                target.style.color = "#999"
                target.style.textDecoration = "line-through"
            }


        }
    }
    //查找删除按钮
    var deletes = document.getElementsByClassName("delete")

    for (var j = 0; j < deletes.length; j++) {
        deletes[j].onclick = function() {
            console.log(this.parentElement.previousElementSibling.style.textDecoration)
                //如果是完成了,删除,如果没有完成不允许删除
            if (this.parentElement.previousElementSibling.style.textDecoration == "line-through") {
                //删除一行
                tbody.removeChild(this.parentElement.parentElement)
            } else {
                alert("努力完成吧")
            }

        }
    }

    //查找修改按钮
    var update = document.getElementsByClassName("update")
    for (var j = 0; j < update.length; j++) {
        //回显
        update[j].onclick = function() {
            var target = this.parentElement.previousElementSibling
                //如果该事项已经完成,则不做修改
            if (target.style.textDecoration == "line-through") {
                alert("事情已经完成,无需修改")
            } else {
                content.value = target.innerText
                add.value = "修改"
                flag = 1
                num = target.getAttribute("index")
            }
        }
    }
}


http://www.kler.cn/a/428854.html

相关文章:

  • Ubuntu 24.04 LTS 更改软件源
  • 网络安全:信息时代的守护者
  • 有限元分析学习——Anasys Workbanch第一阶段笔记(13)网格单元分类、物理场与自由度概念
  • 【统计的思想】假设检验(一)
  • 什么宠物最好养?
  • windows蓝牙驱动开发-蓝牙设备栈
  • 实例教程:BBDB为AHRS算法开发提供完善的支撑环境(下)
  • RPA在IT运维中的实践:自动化监控与维护
  • 瑞芯微RK3566/RK3568开发板安卓11固件ROOT教程,Purple Pi OH演示
  • 【包教包会】CocosCreator3.x——重写Sprite,圆角、3D翻转、纹理循环、可合批调色板、不影响子节点的位移旋转缩放透明度
  • 【python】集合
  • 第3章:文本样式 --[CSS零基础入门]
  • 组件开发的环境准备
  • Linux用户与权限、IP地址与远程管理详解及命令
  • 【Java】类似王者荣耀游戏
  • MONI后台管理系统-数据库设计
  • 【机器学习】支持向量机(SVM)详解:原理与优化
  • Unity 使用LineRenderer制作模拟2d绳子
  • 力扣--LCR 172.统计目标成绩的出现次数
  • 解密时序数据库的未来:TDengine Open Day技术沙龙精彩回顾
  • leetcode 62.不同路径
  • 26备战秋招day17——机器学习基础
  • 1195口袋的天空——并查集+贪心——洛谷
  • Java 基础之 JDBC:连接数据库的强大工具
  • [学习笔记]从Flexbox到Grid布局的实战指南
  • C# 实现 OPCClient(使用 OPCDAAuto.dll)