JavaWeb开发实现备忘录

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

所用技术

HTML,CSS,JavaScript,Servlet,Tomcat 8.5.60,Mysql 5.7

数据库表

开发工具

IDEA,MySQL 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("");
    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;
}

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

(0)

相关推荐

  • 初学Java的备忘录

    虽然以前间或的也看了些书籍,但多是隔靴搔痒,上不了正席,绝不敢说自己懂Java.接触一门新的技术和初恋一样,都是第一次,但不同的是后者一般开始无比甜蜜,结局却很痛苦,而前者则往往开始很痛苦,越到后来却越是有味,简直是欲罢不能.现在我就正处于这个很痛苦的阶段,连一个最简单的Helloworld都运行不出来,总是提示Excepion in thread "main" java.lan.NoClassDefFoundError. 只好上网去查,去搜.记性又不好,所以搜出来赶紧保存下来,常备无

  • JavaWeb开发实现备忘录

    本文实例为大家分享了JavaWeb开发实现备忘录的具体代码,供大家参考,具体内容如下 所用技术 HTML,CSS,JavaScript,Servlet,Tomcat 8.5.60,Mysql 5.7 数据库表 开发工具 IDEA,MySQL Workbench 功能 1.添加未完成事项2.完成事项 项目演示截图 前端设计 <!DOCTYPE html> <html lang="en" > <head>   <meta charset="

  • JavaWeb开发中alias拦截器的使用方法

    在SSH项目中,有时需要由一个Action跳转到另一个Action.有两种方式可以实现Action之间的跳转,一种是chain,另一种是redirectAction,这两种方式之间的区别是chain是在服务器上跳转,可以实现不同Action之间的数据共享:而redirectAction是在客户端进行跳转. 使用chain在不同的Action之间传递参数值,这个功能可以通过alias拦截器来实现. 1. 指定Filter类 在web.xml中设置下面的拦截器: <filter> <filt

  • Javaweb开发环境Myeclipse6.5 JDK1.6 Tomcat6.0 SVN1.8配置教程

    Javaweb开发环境的配置也是比较繁琐的一件事情,虽然理论上使用记事本,完全可以写出一个Javaweb工程, 但是在团队大型开发的Javaweb过程中,你必须配置好Eclipse.SVN.Tomcat与JDK1.6,当然还有Mysql数据库,不过数据库配置的事情属于后台内容,本文仅讨论前台开发环境的配置. 之所以选择Myeclipse6.5是因为其他高版本的Myeclipse实在是太卡,编辑小型程序还好,编辑大型程序完全吃不消,Eclipse的功能毕竟简陋,所以还是选择了旧版本.经典版本Mye

  • JavaWeb开发使用Cookie创建-获取-持久化、自动登录、购物记录、作用路径

    1.cookie是啥?随手百度了网友的说说 简单的说,Cookie就是服务器暂存放在你计算机上的一笔资料,好让服务器用来辨认你的计算机.当你在浏览网站的时候,Web服务器会先送一小小资料放在你的计算机上,当下次你再光临同一个网站,Web服务器会先看看有没有它上次留下的Cookie资料,有的话,就会依据Cookie里的内容来判断使用者,送出特定的网页内容给你. 2.cookie在哪里? 3.cookie可以删除吗? 4.cookie实现原理 第一次请求浏览器,在浏览器的cookie存储区,没有co

  • JavaWeb开发之使用jQuery与Ajax实现动态联级菜单效果

    写在前面,在笔者完成这个demo的时候,笔者发现现在大家已经不用Ajax来完成联级菜单了,实际上笔者这个demo也并不是为了完成这个,笔者主要的学习方向是JavaWeb后台的业务逻辑开发.但是做后台呢还是需要对前端有所了解,尤其是像Ajax这种异步提交数据的技术需要了解并掌握.所以这里笔者这里用了一个联级菜单来练习Ajax异步提交,当然后续还会写几个异步提交表单的demo. 笔者的后台是用的spring+SpringMVC的框架,这里不对这部分进行解释,重点在jQuery和Ajax. 第一,下载

  • JavaWeb开发之模仿知乎首页完整代码

    闲来无事,就根据知乎的首页,参考了一些资料模拟写了下,包含了动态的背景,以及登录和注册功能 登录这里使用的是spring security 注册是ajax发送的 具体代码很简单,一看就知道,包含了数据的检查等 <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <%@ taglib uri="http://java.sun.com/j

  • JavaWeb开发入门第一篇必备知识讲解

    一.基本概念 1.1.WEB开发的相关知识 WEB,在英语中web即表示网页的意思,它用于表示Internet主机上供外界访问的资源. Internet上供外界访问的Web资源分为: 1).静态web资源(如html 页面):指web页面中供人们浏览的数据始终是不变. 2).动态web资源:指web页面中供人们浏览的数据是由程序产生的,不同时间点访问web页面看到的内容各不相同. 静态web资源开发技术:Html 常用动态web资源开发技术:JSP/Servlet.ASP.PHP等 在Java中

  • JavaWeb开发基于ssm的校园服务系统(实例详解)

    利用Javaweb开发的一个校园服务系统,通过发布自己的任务并设置悬赏金额,有些类似于赏金猎人,在这里分享给大家,有需要可以联系我:2186527424: <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-

  • JavaWeb开发入门第二篇Tomcat服务器配置讲解

    一.Tomcat服务器端口的配置 Tomcat的所有配置都放在conf文件夹之中,里面的server.xml文件是配置的核心文件. 如果想修改Tomcat服务器的启动端口,则可以在server.xml配置文件中的Connector节点进行的端口修改 例如:将Tomcat服务器的启动端口由默认的8080改成8081端口 Tomcat服务器启动端口默认配置 <Connector port="8080" protocol="HTTP/1.1" connectionT

  • javaweb开发提高效率利器JRebel详解

    JRebel用了有一段时间了,发现确实好用,节省了很多不必要的时间,提高了开发效率.在这里记录一下他的安装和使用过程,希望能帮助到有需要的人. 官网:https://www.jrebel.com/ 一.JRebel简介 jrebel是国外公司perforce于2007年开发的一款java开发效率工具,旨在帮助java开发人员更快地编写更好的应用程序.jrebel提供了常用的开发IDE如IntelliJ Idea.eclipse.myEclipse.NetBeans等的jrebel插件,可以很方便

随机推荐