前端 | 经典代办框实现(喵喵大王ver)

news2024/9/24 9:17:23

文章目录

  • 📚实现效果
  • 📚模块实现解析
    • 🐇html
    • 🐇css
    • 🐇javascript

📚实现效果

在这里插入图片描述

  • 输入框输入,点击Submit按钮提交,下方显示
    在这里插入图片描述
  • 设置事项上限6条(按照条数设置限制,默认每条事项是简约的;长文段自动换行,如果都是长文段超过显示范围就隐藏了)
    在这里插入图片描述
  • 悬浮点击后确认删除
    在这里插入图片描述

📚模块实现解析

🐇html

  • 搭框架
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>喵喵大王立大功</title>
        <link rel="stylesheet" href="./style.css">
    </head>
    <body>
        <main id="board">
            <!-- 代办框 -->
            <section class="container">
                <!-- 标题 -->
                <div class="heading">
                  <img class="heading__img" src="https://lalayouyi.github.io/picx-images-hosting/mypage/吐舌.9rj7cimwv0.webp">
                  <h1 class="heading__title">To-Do List</h1>
                </div>
                <form class="form">
                  <div>
                    <!-- ~ Today I need to ~ -->
                    <label class="form__label" for="todo">~ Today I need to ~</label>
                    <!-- 待办事项输入框 -->
                    <input class="form__input"
                         type="text" 
                         id="todo" 
                         name="to-do"
                         size="30"
                         required>
                    <!-- 提交按钮 -->
                    <button class="button"><span>Submit</span></button>
                  </div>
                </form>
                <div>
                  <!-- 代办事项列表 -->
                  <ul class="toDoList">
                  </ul>
                </div>
                <div>
                    <!-- 代办框右下角那三个猫爪图片 -->
                    <img class="cute1" src="./src/cute.png">
                    <img class="cute2" src="./src/cute2.png">
                    <img class="cute3" src="./src/cute3.png">
                </div>
            </section>
        </main>
    </body>
    <script src="./js/todolist.js"></script>
    </html>
    

🐇css

  • 页面整体布局:通过html, body的样式设置将页面内容垂直和水平居中,并且设定了统一的文字样式。

  • 整个面板样式:铺满视口、溢出隐藏、透视效果等。

  • 代办框样式:使用.container样式定义了一个相对定位的代办框,包括了宽度、高度、背景图案、圆角边框和阴影效果

  • 分别设定标题、输入框、按钮和待办事项列表、页面底部的三个猫猫爪子的样式。(rem单位是相对于根元素字体大小的单位,因此可以根据根元素的字体大小进行缩放,适配性和灵活性更好)

    html, body {
        padding: 0;
        margin: 0;
        /* 设置整个页面内容垂直和水平居中 */
        display: flex;
        justify-content: center;
        align-items: center;
        color: hsl(198, 1%, 29%);
        font-family: FangSong;
        text-align: center;
        font-size: 130%;  
    }
    
    * {
        padding: 0;
        margin: 0;
    }
    
    /* 整个面板 */
    #board {
        position: relative;
        /* 铺满整个视口 */
        width: 100vw;
        height: 100vh;
        background-color: #F1EEE7;
        /* 溢出隐藏 */
        overflow: hidden;
        /* 透视效果 */
        perspective: 1600px;
        /* 盒模型的属性 */
        /* 元素的宽度和高度包括内容、内边距和边框,而不包括外边距。 */
        box-sizing: border-box;
        padding: 50px;
    }
    
    /* #region代办框start */
    /* 整个代办框 */
    .container {
        position: relative;
        height: 85vh;
        width: 35vw;
        background: #f1f5f8;
        /* 背景圆点绘制,每个重复的小方块大小为 ​25px × 25px​ */
        background-image: radial-gradient(#bfc0c1 7.2%, transparent 0);
        background-size: 25px 25px;
        border-radius: 20px;
        box-shadow: 4px 3px 7px 2px #00000040;
        box-sizing: border-box;
        /* 水平居中对齐 */
        margin: 0 auto;
        margin-top: 5vh;
    }
    
    /* 标题 */
    .heading {
        display: flex;
        align-items: center;
        justify-content: center;
        margin-bottom: 1rem;
    }
    /* To-Do List部分样式 */
    .heading__title {
        transform: rotate(2deg);
        padding: 0.2rem 1.2rem;
        border-radius: 20% 5% 20% 5%/5% 20% 25% 20%;
        background-color: hsla(53, 100%, 93%, 0.708);
        font-size: 1.5rem;
    }
    .heading__img {
        width: 22%;
    }
    /* ~ Today I need to ~ */
    .form__label {
        display: block;
        margin-top: -1.1rem;
        margin-bottom: 0.5rem;
    }
    /* 输入框 */
    .form__input {
        box-sizing: border-box;
        background-color: transparent;
        padding: 0.3rem;
        /* 边框设置 */
        border-bottom-right-radius: 15px 3px;
        border-bottom-left-radius:3px 15px;
        border: solid 3px transparent;
        border-bottom: dashed 3px #c6beb1;
        /* 字体设置 */
        font-size: 1rem;
        color: hsla(260, 2%, 25%, 0.7);
        width: 70%;
        margin-bottom: 20px;
        /* 获得焦点时 */
        &:focus {
            /* 去掉默认的外边框样式 */
            outline: none;
            /* 框变为实线,颜色为#c6beb1 */
            border: solid 3px #c6beb1;
        }
    }
    /* submit按钮 */
    .button {
        padding: 0;
        border: none;
        /* 顺时针旋转4度 */
        transform: rotate(4deg);
        /* 变换的起点为中心点 */
        transform-origin: center;
        text-decoration: none;
        padding-bottom: 3px;
        border-radius: 5px;
        /* 添加一个垂直的盒子阴影效果 */
        box-shadow: 0 2px 0 hsl(198, 1%, 29%);
        /* 过渡效果的时间和缓动函数 */
        transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
        /* Base64编码的背景图像 */
        background-image: url('data:image/gif;base64,R0lGODlhBAAEAIABAAAAAAAAACH/C1hNUCBEYXRhWE1QPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNS4wLWMwNjEgNjQuMTQwOTQ5LCAyMDEwLzEyLzA3LTEwOjU3OjAxICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOnhtcE1NPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvbW0vIiB4bWxuczpzdFJlZj0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlUmVmIyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgQ1M1LjEgV2luZG93cyIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDo5NUY1OENCRDdDMDYxMUUyOTEzMEE1MEM5QzM0NDVBMyIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDo5NUY1OENCRTdDMDYxMUUyOTEzMEE1MEM5QzM0NDVBMyI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOjk1RjU4Q0JCN0MwNjExRTI5MTMwQTUwQzlDMzQ0NUEzIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjk1RjU4Q0JDN0MwNjExRTI5MTMwQTUwQzlDMzQ0NUEzIi8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+Af/+/fz7+vn49/b19PPy8fDv7u3s6+rp6Ofm5eTj4uHg397d3Nva2djX1tXU09LR0M/OzczLysnIx8bFxMPCwcC/vr28u7q5uLe2tbSzsrGwr66trKuqqainpqWko6KhoJ+enZybmpmYl5aVlJOSkZCPjo2Mi4qJiIeGhYSDgoGAf359fHt6eXh3dnV0c3JxcG9ubWxramloZ2ZlZGNiYWBfXl1cW1pZWFdWVVRTUlFQT05NTEtKSUhHRkVEQ0JBQD8+PTw7Ojk4NzY1NDMyMTAvLi0sKyopKCcmJSQjIiEgHx4dHBsaGRgXFhUUExIREA8ODQwLCgkIBwYFBAMCAQAAIfkEAQAAAQAsAAAAAAQABAAAAgYEEpdoeQUAOw==');
        background-color: hsla(0, 0%, 100%, 0.7);
    }
    /* 按钮内文本样式 */
    .button span {
        background: #f1f5f8;
        display: block;
        padding: 0.5rem 1rem;
        border-radius: 5px;
        border: 2px solid hsl(198, 1%, 29%);
    }
    /* 按钮在激活状态和获取焦点时 */
    .button:active, .button:focus {
        transform: translateY(4px);
        padding-bottom: 0px;
        outline: 0;
    }
    
    /* 代办事项列表 */
    .toDoList {
        padding-left: 2.5rem;
        text-align: left;
    }
    li {
        position: relative;
        padding-top: 0.4rem;
        font-size: 24px;
        color: #3c4654;
        /* 实现自动换行 */
        word-break: break-all;
    }
    /* 悬停时添加删除线效果 */
    li:hover {
        text-decoration: line-through #d5c8a0;
    }
    
    /* 右下角的三个爪子 */
    .cute1{
        position: absolute; 
        bottom: 1%; 
        right: 14%; 
        width: 20%;
        height: 20%;
    }
    .cute2{
        position: absolute; 
        bottom: 14%; 
        right: 1%; 
        width: 20%;
        height: 20%;
    }
    .cute3{
        position: absolute; 
        bottom: 0; 
        right: 0; 
        width: 20%;
        height: 20%;
    }
    /* #endregion代办框end */
    

🐇javascript

  • 获取页面中的元素:锁定了包含表单的元素(form)、表单输入框(input)和代办事项列表(ul)。
  • 添加事件监听器
    • 当表单(form)提交时,阻止默认的提交行为,并且获取输入框中的待办事项内容。如果待办事项列表中已经有6个或以上的项,则会弹出一个警告框。然后将新的待办事项以li的形式添加到代办事项列表中,并清空输入框内容。
    • 当代办事项列表中的项被点击时,会弹出确认对话框,确认是否删除该待办事项。如果确认删除,则从页面中删除对应的待办事项。
    (() => { 
        // 锁定元素
        const form = document.querySelector(".form"); 
        const input = form.querySelector(".form__input"); 
        const ul = document.querySelector(".toDoList"); 
    
        // 代办提交时
        form.addEventListener('submit', e => {
            // 阻止表单的默认提交行为
            e.preventDefault(); 
            // 生成唯一的id
            let itemId = String(Date.now()); 
            // 获取输入框中的待办事项内容
            let toDoItem = input.value; 
            // 如果待办事项列表已经有6个或以上的项
            if (ul.children.length >= 6) { 
                alert("喵喵大王处理不过来啦!"); 
                return;
            }
            // 将待办事项添加到页面中
            const li = document.createElement('li'); 
            li.setAttribute("data-id", itemId); 
            li.innerText = toDoItem; 
            ul.appendChild(li);
            
            // 清空输入框
            input.value = ''; 
        });
    
        // 点击删除时
        ul.addEventListener('click', e => {
            // 获取被点击项的id
            let id = e.target.getAttribute('data-id') 
            // 如果被点击的不是待办事项,则退出函数
            if (!id) return 
            // 弹出确认对话框,确认是否删除该待办事项
            if (confirm("好耶,喵喵大王又做完一件事♪(^∇^*)")) { 
                // 从页面中删除该待办事项
                var li = document.querySelector('[data-id="' + id + '"]'); 
                ul.removeChild(li); 
            }
        });
    })();
    
  • 锁定元素:使用document.querySelector方法选择具有指定类名的元素,存储在变量中。
  • 阻止表单的默认提交行为:e.preventDefault();
  • 为li元素设置属性:li.setAttribute("data-id", itemId);
  • 将li元素添加到ul元素中:ul.appendChild(li);
  • let itemId = String(Date.now())用了JavaScript内置的Date对象来获取当前时间的毫秒数,然后使用String()函数将其转换为字符串赋值给itemId变量。以此生成一个“基本”唯一的ID来标识页面中的代办条例,以便在后续的操作中对其进行识别和处理。
  • 获取被点击项的id:let id = e.target.getAttribute('data-id')
  • 从页面中删除该待办事项:ul.removeChild(li);

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

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

相关文章

go-mysql-transfer 同步数据到es

同步数据需要注意的事项 前提条件 1 要同步的mysql 表必须包含主键 2 mysql binlog 必须是row 模式 3 不支持程序运行过程中修改表结构 4 要赋予连接mysql 账号的权限 reload, replication super 权限 如果是root 权限则不需要 安装 go-mysql-transfer ​ git clone…

MySQL从入门到高级 --- 5.DQL基本操作

文章目录 第五章&#xff1a;5.基本操作 - DQL5.1 运算符逻辑运算符位运算符算术运算符 5.2 条件查询5.3 排序查询5.4聚合查询5.4.1 聚合查询-NULL值处理 5.5 分组查询 - group by5.5.1 条件筛选 - having5.6 分页查询 - limit5.7 INSERT INTO SELECT 语句5.8 练习5.9 正则表达…

服务器端优化-Redis内存划分和内存配置

6、服务器端优化-Redis内存划分和内存配置 当Redis内存不足时&#xff0c;可能导致Key频繁被删除、响应时间变长、QPS不稳定等问题。当内存使用率达到90%以上时就需要我们警惕&#xff0c;并快速定位到内存占用的原因。 有关碎片问题分析 Redis底层分配并不是这个key有多大&…

单体服务-微服务-分布式 [三兄弟的区别]

大家好&#xff0c;我是晓星航。今天为大家带来的是 单体服务-微服务-分布式 [三兄弟的区别] 相关的讲解&#xff01;&#x1f60a; 文章目录 1.单体服务1.1单体服务架构的基本介绍1.2单体服务的优缺点 2.微服务2.1微服务架构的基本介绍2.2微服务架构的优缺点 3.分布式4.三兄弟…

OpenCV4.9去运动模糊滤镜(68)

返回:OpenCV系列文章目录&#xff08;持续更新中......&#xff09; 上一篇:OpenCV4.9失焦去模糊滤镜(67) 下一篇&#xff1a;OpenCV如何通过梯度结构张量进行各向异性图像分割(69) 目标 在本教程中&#xff0c;您将学习&#xff1a; 运动模糊图像的 PSF 是多少如何恢复运动…

SQLI-labs-第十五关和第十六关

目录 知识点&#xff1a; 第十五关 1、判断注入点 2、判断当前数据库 3、判断表名 4、判断字段名 5、爆值 第十六关 1、判断注入点 知识点&#xff1a; POST方式的时间盲注 对应的函数利用&#xff0c;可参考SQLI-labs-第九关和第十关_sqllab第十关-CSDN博客 第十五…

Pycharm的安装配置

pycharm的安装配置 1.pycharm的安装 pycharm进入官网下载即可&#xff1a;官网。 想下载老版本的点这里。 pycharm分为专业版和社区版&#xff0c;专业版只能免费30天过了就需要&#x1f4b4;&#xff0c;社区版是开源的&#xff0c;功能没有专业版全面但是也差不多够用。 …

智慧水务-水源监控管理系统

通过物联网结合在线传感器&#xff0c;如液位、水质和视频&#xff0c;每一个水库的水位和降雨量&#xff0c;以及每个水源井的水位&#xff0c;泵站状态&#xff0c;流量和网站远程图像监控&#xff0c;现场提供准确和及时的信息&#xff0c;以确保适当的蓄水水库的防洪安全。…

新篇章!沃飞长空成为同中信海直签约的唯一中国eVTOL企业

随着城市地面交通的愈发拥堵&#xff0c;人们逐渐把目光投向天空。打个“空中的士”上班的城市空中出行场景&#xff0c;受到越来越多方的期待&#xff0c;相应的&#xff0c;eVTOL(飞行汽车)行业的相关投资与合作也愈发火热。 4月30日&#xff0c;国内领先的eVTOL&#xff08…

FX110网:新西兰FMA针对潜在的快速致富骗局发出警报

如果某件事听起来好得令人难以置信&#xff0c;那么它通常就是假的。根据新西兰金融市场监管机构FMA的说法&#xff0c;这种久经考验的真实市场说法可能适用于 Equity Budget&#xff0c;该公司承诺每天高达 7% 的“不切实际的回报”。此外&#xff0c;它缺乏适当的监管&#x…

[LitCTF 2023]Ping、[SWPUCTF 2021 新生赛]error、[NSSCTF 2022 Spring Recruit]babyphp

[LitCTF 2023]Ping 尝试ping一下127.0.0.1成功了&#xff0c;但要查看根目录时提示只能输入IP 查看源代码&#xff0c;这段JavaScript代码定义了一个名为check_ip的函数&#xff0c;用于验证输入是否为有效的IPv4地址。并且使用正则表达式re来匹配IPv4地址的格式。 对于这种写…

python(简单制作注册登录系统)

制作一个注册登录模块 注册&#xff1a;将用户填入的账户和密码保存到一个文件(users.bin) 登陆&#xff1a;将用户填入账户密码和users.bin中保存的账户密码进行比对,如果账户和密码完全相同 那么登录成功&#xff0c;否则登录失败。 分析&#xff1a; 注册部分--主要涉及到的…

图搜索算法 - 深度优先搜索法(DFS)

图搜索算法 图搜索算法也可以叫图的遍历&#xff0c;指从图上任意一个顶点出发&#xff0c;访问图上的所有顶点&#xff0c;而且只能访问一次。这和上一节树的遍历功能类似。但由于图没有层级结构&#xff0c;也没有类似树的根结点那样的特殊顶点&#xff0c;因此相对要复杂一…

什么是模版方法模式,有哪些应用?

模板方法模式是一种行为设计模式&#xff0c;他的主要作用就是复用代码。在很多时候&#xff0c;我们的代码中可能会有-些公共的部分并且还有一些定制的部分&#xff0c;那么公共这部分就可以定义在一个父类中&#xff0c;然后将定制的部分实现在子类中。这样子类可以根据需要扩…

微信小程序如何使用svg矢量图标

微信小程序如何使用自定义SVG矢量图标 在微信小程序中&#xff0c;经常会用到小图标来装饰界面&#xff0c;我们常用的方法就是引用第三方的图标&#xff0c;但会存在收费或者找不到合适的图标&#xff0c;这时候我建议可以自行编写svg图标代码&#xff0c;就可以随心所欲的使…

JDK 17有可能代替 JDK 8 吗

不好说&#xff0c;去 Oracle 化是很多公司逐步推进的政策。 JVM 有 OpenJ9。很多公司可能会用 IBM 的版本。 JDK 这东西&#xff0c;能用就不会升级。 JDK 太基础了&#xff0c;决定了后面的很多 jar 的版本。 https://www.ossez.com/t/jdk-17-jdk-8/14102

【源码+文档+安装教程】校园社团信息管理系统

摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了校园社团信息管理系统的开发全过程。通过分析校园社团信息管理系统管理的不足&#xff0c;创建了一个计算机管理校园社团信息管理系统的方案。文章介绍了校园社团…

GPU系列(六)-NVIDIA GPU 驱动安装

1. 安装驱动 1.1 查看系统是否识别显卡 lspci | grep -i vga03:00.0 VGA compatible controller: NVIDIA Corporation GP102 [TITAN X] (rev a1) 0a:00.0 VGA compatible controller: Matrox Electronics Systems Ltd. G200eR2 (rev 01) 识别出显卡为 NVIDIA 的 TITAN X。 …

对比试验系列:Faster—RCNN配置及训练自己数据集

一、源码下载 GitHub - bubbliiiing/faster-rcnn-pytorch: 这是一个faster-rcnn的pytorch实现的库&#xff0c;可以利用voc数据集格式的数据进行训练。这是一个faster-rcnn的pytorch实现的库&#xff0c;可以利用voc数据集格式的数据进行训练。. Contribute to bubbliiiing/fa…

【LeetCode算法】1768. 交替合并字符串

提示&#xff1a;此文章仅作为本人记录日常学习使用&#xff0c;若有存在错误或者不严谨得地方欢迎指正。 文章目录 一、题目二、思路三、解决方案 一、题目 给你两个字符串 word1 和 word2 。请你从 word1 开始&#xff0c;通过交替添加字母来合并字符串。如果一个字符串比另…