返回顶部
首页 > 资讯 > 后端开发 > Python >JavaWeb开发实现备忘录
  • 205
分享到

JavaWeb开发实现备忘录

2024-04-02 19:04:59 205人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

本文实例为大家分享了Javaweb开发实现备忘录的具体代码,供大家参考,具体内容如下 所用技术 html,CSS,javascript,Servlet,Tomcat 8.5.60,M

本文实例为大家分享了Javaweb开发实现备忘录的具体代码,供大家参考,具体内容如下

所用技术

htmlCSSjavascript,Servlet,Tomcat 8.5.60,Mysql 5.7

数据库

开发工具

ideamysql Workbench

功能

1、添加未完成事项
2、完成事项

项目演示截图

前端设计

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title>To-Do-List设计</title>
  <link rel="stylesheet" href="./style.css" >

</head>
<body>
<section class="container">
  <div class="heading">
    <img class="heading_img" src="girl.svg">
    <h1 class="heading_title">To-Do List</h1>
  </div>
  <fORM class="form">
    <div>
      <label class="form_label" for="todo">~ Today I want to do ~</label>
      <input class="form_input"
           type="text" 
           id="todo" 
           name="to-do"
           size="30"
           required>
      <button class="button" type="type"><span>Submit</span></button>
    </div>
  </form>
  <div>
    <ul class="toDoList"></ul>
  </div>
</section>

<!-- partial -->
  <script src="./script.js"></script>
</body>
</html>
body {
    background-color: #f7d3c1;
    min-height: 70vh;
    padding: 1rem;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #494a4b;
    font-family: "Gochi Hand", cursive;
    text-align: center;
    font-size: 130%;
}

@media only screen and (min-width: 500px) {
    body {
        min-height: 100vh;
    }
}

.container {
    width: 100%;
    height: auto;
    min-height: 500px;
    max-width: 500px;
    min-width: 250px;
    background: #f1f5f8;
    background-image: radial-gradient(#bfc0c1 7.2%, transparent 0);
    background-size: 25px 25px;
    border-radius: 20px;
    box-shadow: 4px 3px 7px 2px #000000;
    padding: 1rem;
    box-sizing: border-box;
}

.heading {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
}

.heading_title {
    transform: rotate(2deg);
    padding: 0.2rem 1.2rem;
    border-radius: 20% 5% 20% 5%/5% 20% 25% 20%;
    background-color: lightpink;
    font-size: 1.5rem;
}

@media only screen and (min-width: 500px) {
    .heading_title {
        font-size: 2rem;
    }
}

.heading_img {
    width: 24%;
}

.form_label {
    display: block;
    margin-bottom: 0.5rem;
}

.form_input {
    box-sizing: border-box;
    background-color: transparent;
    padding: 0.7rem;
    border-bottom-right-radius: 15px 3px;
    border-bottom-left-radius: 3px 15px;
    border: solid 3px transparent;
    border-bottom: dashed 3px #95a9ea;
    font-family: "Gochi Hand", cursive;
    font-size: 1rem;
    color: rgba(63, 62, 65, 0.7);
    width: 70%;
    margin-bottom: 20px;
}

.form_input:focus {
    outline: none;
    border: solid 3px #95a9ea;
}

@media only screen and (min-width: 500px) {
    .form_input {
        width: 60%;
    }
}

.button {
    padding: 0;
    border: none;
    transform: rotate(4deg);
    transform-origin: center;
    font-family: "Gochi Hand", cursive;
    text-decoration: none;
    padding-bottom: 3px;
    border-radius: 5px;
    box-shadow: 0 2px 0 #494a4b;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    background-image: url("data:image/gif;base64,R0lGODlhBAAEAIABAAAAAAAAACH/C1hNUCBEYXRhWE1QPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNS4wLWMwNjEgNjQuMTQwOTQ5LCAyMDEwLzEyLzA3LTEwOjU3OjAxICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93D3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOnhtcE1NPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvbW0vIiB4bWxuczpzdFJlZj0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlUmVmIyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgQ1M1LjEgV2luZG93cyIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDo5NUY1OENCRDDDMDYxMUUyOTEzMEE1MEM5QzM0NDVBMyIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDo5NUY1OENCRTdDMDYxMUUyOTEzMEE1MEM5QzM0NDVBMyI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOjk1RjU4Q0JCN0MwNjExRTI5MTMwQtUwQzlDMzQ0NUEzIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjk1RjU4Q0JDN0MwNjExRTI5MTMwQTUwQzlDMzQ0NUEzIi8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+Af/+/fz7+vn49/b19PPy8fDv7u3s6+rp6Ofm5eTj4uHg397d3Nva2djX1tXU09LR0M/OzczLysnIx8bFxMPCwcC/vr28u7q5uLe2tbSzsrGwr66trKuqqainpqWko6KhoJ+enZybmpmYl5aVlJOSkZCPjo2Mi4qJiIeGhYSDgoGAf359fHt6eXh3dnV0c3JxcG9ubWxramloZ2ZlZGNiYWBfXl1cW1pZWFdWVVRTUlFQT05NTEtKSUhHRkVEQ0JBQD8+PTw7Ojk4NzY1NDMyMTAvLi0sKyopKCcmJSQjIiEgHx4dHBsaGRgXFhUUExIREA8ODQwLCgkIBwYFBAMCAQAAIfkEAQAAAQAsAAAAAAQABAAAAgYEEpdoeQUAOw==");
    background-color: rgba(0, 119, 255, 0.7);
}

.button span {
    background: #f1f5f8;
    display: block;
    padding: 0.5rem 1rem;
    border-radius: 5px;
    border: 2px solid #494a4b;
}

.button:active, .button:focus {
    transform: translateY(4px);
    padding-bottom: 0px;
    outline: 0;
}

.toDoList {
    text-align: left;
}

.toDoList li {
    position: relative;
    padding: 0.5rem;
}

.finish{
    text-decoration: line-through wavy #fb8524b6;
}
.toDoList li:hover {
    text-decoration: line-through wavy #fb8524b6;
}
var htmlRoot = document.querySelector("html");
var ulTodoList = document.querySelector("ul.toDoList");
var input = document.querySelector("input#todo");

function finishTodoItem() {
    //this 就是触发事件的元素(就是用户点击的元素)
    var id = this.dataset.id;
    var url = "/finish?id=" + id;
    var xhr = new XMLHttpRequest();
    var self = this;
    xhr.open("get",url);
    xhr.send();
    xhr.onload = function () {
        self.classList.add("finish");
        self.onclick = null;
    }
}

function appendTodo(todo) {
    var todoLi = document.createElement("li");
    todoLi.innerText = todo.todo;
    if(todo.state == true){
        todoLi.classList.add("finish");
    }else{
        todoLi.onclick = finishTodoItem;
        todoLi.dataset.id = todo.id;
    }
    ulTodoList.appendChild(todoLi);
}

//为"submit"按钮绑定save函数
function save() {
    var todoInput = input.value;
    var url = "/save?todo=" + encodeURI(todoInput);
    var xhr = new XMLHttpRequest();
    function success() {
        var todo = {
            "id":parseInt(xhr.responseText),
            "todo":todoInput,
            "state":0,
        };

        appendTodo(todo);
    }
    xhr.onload = success;
    xhr.open("get",url);
    xhr.send();
}
var submitBtn = document.querySelector(".button");
submitBtn.onclick =  save;

//页面加载完成之后,请求列表资源
function LoadTodoList() {
    var xhr = new XMLHttpRequest();
    function success() {
        if (xhr.status != 200){
            htmlRoot.innerHTML = xhr.responseText;
            return;
        }

        //1、JS进行JSON的反序列化
        var todoList = JSON.parse(xhr.responseText);
        //遍历每一项,添加到DOM树中
        for (var todo of todoList){
            appendTodo(todo);
        }
    }
    xhr.onload = success;
    xhr.open("get","/list");
    xhr.send();
}
LoadTodoList();

后端设计

@WEBServlet("/finish")
public class FinishServlet extends httpservlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //1、获取用户点击事项的id
        req.setCharacterEncoding("utf-8");
        String id = req.getParameter("id");
        //进行数据库表的更新
        try (Connection c = DBUtil.connection()) {
            String sql = "UPDATE item set state = 1 WHERE id=?";
            try (PreparedStatement s = c.prepareStatement(sql)) {
                s.setString(1, id);

                s.executeUpdate();
            }
        } catch (SQLException exc) {
            throw new ServletException(exc);
        }
    }
}
@WebServlet("/list")
public class ListServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //1、从数据库中查出List<待办事项>todolist
        List<TodoItem> todolist = new ArrayList<>();
        try (Connection c = DBUtil.connection()){
            String sql = "SELECT id,todo,state FROM item ORDER BY id";
            try(PreparedStatement s = c.prepareStatement(sql)){
                try (ResultSet rs = s.executeQuery()){
                    while(rs.next()){
                        TodoItem todo = new TodoItem();
                        todo.id = rs.getInt("id");
                        todo.todo = rs.getString("todo");
                        todo.state = rs.getBoolean("state");

                        todolist.add(todo);
                    }
                }
            }
        } catch (SQLException exc) {
            throw new ServletException(exc);
        }

        //2、把todolist序列化成JSON格式的字符串
        ObjectMapper objectMapper = new ObjectMapper();
        String s = objectMapper.writeValueAsString(todolist);
        //3、进行响应输出
        resp.setCharacterEncoding("utf-8");
        resp.setContentType("application/json");
        resp.getWriter().println(s);

    }
}
@WebServlet("/save")
public class SaveServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //1、读取用户填写的内容
        req.setCharacterEncoding("utf-8");
        String todo = req.getParameter("todo");
        //2、执行SQL,把内容写入表中
        int id;
        try (Connection c = DBUtil.connection()){
            String sql = "INSERT INTO item(todo)VALUES(?)";
            try (PreparedStatement s = c.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS)){
                s.setString(1,todo);

                s.executeUpdate();

                try(ResultSet rs = s.getGeneratedKeys()){
                    rs.next();
                    id = rs.getInt(1);
                }
            }
        } catch (SQLException exc) {
            throw new ServletException(exc);
        }
        //3、手动写一个JSON成功
        resp.setCharacterEncoding("utf-8");
        resp.setContentType("application/json");
        resp.getWriter().println(id);
    }
}
public class TodoItem {
    public Integer id;
    public String todo;
    public boolean state;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: JavaWeb开发实现备忘录

本文链接: https://lsjlt.com/news/152249.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaWeb开发实现备忘录
    本文实例为大家分享了JavaWeb开发实现备忘录的具体代码,供大家参考,具体内容如下 所用技术 HTML,CSS,JavaScript,Servlet,Tomcat 8.5.60,M...
    99+
    2024-04-02
  • Android如何实现备忘录
    这篇文章主要介绍了Android如何实现备忘录,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档一、首先创建保存数...
    99+
    2023-06-25
  • android怎么实现备忘录提醒
    要实现备忘录提醒功能,可以使用Android的AlarmManager类和NotificationManager类。以下是一个简单的...
    99+
    2023-08-29
    android
  • 案例:python中实现51备忘录
    1.添加Memo类,至少包含id,name,thing,date四个属性,date可以暂时使用字符串表示,比如‘1.2’,‘3.8’,暂时不用考虑时间相关模块 2.id属性为只读,其他属性可读写 3.添加MemoAdmin类,作为主体程序,...
    99+
    2023-01-31
    备忘录 案例 python
  • Android备忘录功能怎么实现
    要实现Android的备忘录功能,可以按照以下步骤进行:1. 创建一个新的Android项目。2. 在布局文件中,设计一个界面用于显...
    99+
    2023-08-29
    Android
  • 开发者常用及实用Linux Shell命令备忘录(小结)
    最近都需要在 linux 系统下开发,所以经常需要在终端中进行操作。Linux 有很多 shell 命令可以帮助我们完成任务,但不常使用的话就会忘记掉。 本篇作为命令备忘录,我会将实际工作当中用到的命令记录下来,并长期保...
    99+
    2022-06-04
    Linux Shell常用命令 Linux Shell 命令
  • python代码实现备忘录案例讲解
    文件操作 TXT文件 读取txt文件 读取txt文件全部内容: def read_all(txt): ...: with open(txt,'r') as f: ...
    99+
    2024-04-02
  • android如何实现备忘录闹钟功能
    要实现备忘录闹钟功能,可以使用Android的AlarmManager和NotificationManager两个类。1. 首先,在...
    99+
    2023-08-29
    android
  • 基于JavaScript实现HarmonyOS备忘录服务卡片
    目录一、前言二、实现效果三、创建工程四、生成服务卡片五、调试预览一、前言 HarmonyOS发布,服务卡片成为了亮点之一。那么除了开发应用,服务卡片也成了必学的知识。备忘录是现在每台...
    99+
    2024-04-02
  • Javaweb实现邮件发送
    本文实例为大家分享了Javaweb实现邮件发送的具体代码,供大家参考,具体内容如下 发送邮件使用的是SMTP协议:一般是smtp.xxx.com ,比如smtp.qq.com 接收邮...
    99+
    2024-04-02
  • VBS中是如何实现备忘录启动功能
    小编给大家分享一下VBS中是如何实现备忘录启动功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!代码如下:msg = Array("...
    99+
    2023-06-08
  • JavaWeb实现自动登录功能
    本文实例为大家分享了JavaWeb实现自动登录功能的具体代码,供大家参考,具体内容如下 自动登录是通过存储cookie值来实现的。 工程目录如下: login.jsp: <...
    99+
    2024-04-02
  • javaweb实现注册登录页面
    本文实例为大家分享了javaweb实现注册登录页面的具体代码,供大家参考,具体内容如下 <%@ page language="java" contentType="text/h...
    99+
    2024-04-02
  • Python中怎么实现一个微信提醒备忘录
    Python中怎么实现一个微信提醒备忘录,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1任何的记录与提取1).任务记录为了便于爬取,推荐使用网页版的在线记事本,现在这种工具...
    99+
    2023-06-16
  • 基于JavaScript如何实现HarmonyOS备忘录服务卡片
    这篇文章主要介绍“基于JavaScript如何实现HarmonyOS备忘录服务卡片”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“基于JavaScript如何实现HarmonyOS备忘录服务卡片”文章...
    99+
    2023-06-30
  • 如何利用MySQL和C++开发一个简单的备忘录功能
    要利用MySQL和C++开发一个简单的备忘录功能,你可以按照以下步骤进行:1. 安装MySQL数据库:首先,你需要安装MySQL数据...
    99+
    2023-10-10
    MySQL
  • JavaWeb Servlet实现网页登录功能
    上次写了一篇JDBC工具类实现登录功能,但是只能在控制台实现输入用户名密码。这次使用了Servlet来实现登录功能,可以通过在页面上输入账号密码,然后提交表单,查询数据库,从而实现登...
    99+
    2024-04-02
  • javaweb如何实现登录验证码
    这篇文章给大家分享的是有关javaweb如何实现登录验证码的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。使用:Controller:生成验证码@RequestMapping("/user/check.j...
    99+
    2023-05-30
    javaweb
  • javaweb实现简易邮件发送
    本文实例为大家分享了javaweb实现简易邮件发送的具体代码,供大家参考,具体内容如下 1.邮件发送 2.jar包的支持 activation-1.1.1.jar mail-1.4...
    99+
    2024-04-02
  • C#实战之备忘录的制作详解
    目录1.概述2.内容详述3.前台代码4.效果演示1.概述 前几天群里有人问如何制作备忘录,感觉这样一个小实例挺适合新手们入门学习使用,所以就抽空做了出来。界面如下图 这个备忘录主要...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作