综合大练习
任务目的
结合前两个任务所掌握的HTML、CSS、JavaScript知识,实现一个中等复杂度的Web网站实现
任务时间
- 初级班:10天
- 中级班:10天
JavaScript深度学习
任务描述
深度学习JavaScript,仔细掌握作用域、原型、闭包等概念,掌握一些基本的设计模式,为后续的大作业打下基础。
完成以下内容的学习笔记撰写,推荐发到自己的博客或Github上。
- JavaScript作用域学习笔记
- JavaScript原型学习笔记
- JavaScript闭包学习笔记
- JavaScript构造函数学习笔记
- JavaScript面向对象编程学习笔记
- JavaScript设计模式学习笔记
参考资料
- 鸟哥:Javascript作用域原理
- 理解 JavaScript 作用域和作用域链
- 强大的原型和原型链
- js原型链原理看图说明
- 理解JavaScript原型
- 深入理解javascript原型和闭包
- 学习Javascript闭包
- javascript的闭包
- JavaScript 闭包深入理解
- 理解 Javascript 的闭包
- Javascript 面向对象编程
- JavaScript继承详解
- JavaScript继承方式详解
- JavaScript探秘:构造函数 Constructor
- 理解Javascript constructor实现原理
- Javascript中this关键字详解
- Javascript的this用法
- 深入浅出 JavaScript 中的 this
- JavaScript The Core
- Eloquent JavaScript
- JavaScript Garden
- JavaScript设计模式深入分析
- 常用的Javascript设计模式
- Learning JavaScript Design Patterns
- LS的中文版:学用 JavaScript 设计模式
综合练习
任务描述
参考设计稿实现一个简单的个人任务管理系统:如下图
任务需求描述:
- 最左侧为任务分类列表,支持查看所有任务或者查看某个分类下的所有任务
- 初始时有一个
默认分类
,进入页面时默认选中默认分类
。 - 分类支持多层级别。
- 分类支持增加分类、删除分类两个操作
- 在左侧分类最下方有添加操作,点击后弹出浮层让输入新分类的名称,新分类将会被添加到当前选中的分类下。浮层可以为自行设计实现,也可以直接使用
prompt
。 - 当鼠标
hover
过某一个分类时,右侧会出现删除按钮,点击后,弹出确认是否删除的浮层,确认后删除掉该分类。弹出的确认浮层可以自行设计实现,也可以直接使用confirm
。 - 不能为
默认分类
添加子分类,也不能删除默认分类
。
- 在左侧分类最下方有添加操作,点击后弹出浮层让输入新分类的名称,新分类将会被添加到当前选中的分类下。浮层可以为自行设计实现,也可以直接使用
- 每一个分类名字后显示一个当前分类下的未完成任务总数量。
- 初始时有一个
- 中间列为任务列表,用于显示当前选中分类下的所有未完成任务
- 任务列表按日期(升序或者降序,自行设定)进行聚类
- 用不同的字体颜色或者图标来标示任务的状态,任务状态有两张:
已完成
或未完成
。 - 下方显示
新增任务
的按钮,点击后,右侧列会变成新增任务编辑界面。 - 单击某个任务后,会在右侧显示该任务的详细信息。
- 在任务列表的上方有任务筛选项,可以选择在任务列表中显示所有任务,或者只显示
已完成
或者未完成
的任务。
- 右侧为任务详细描述部分
- 第一行显示任务标题,对于未完成的任务,在标题行的右侧会有
完成任务
的操作按钮及编辑任务
的按钮。 - 点击
完成任务
按钮时,弹出确认是否确认完成的浮层,确认后该任务完成,更新中间列任务的状态。弹出的确认浮层可以自行设计实现,也可以直接使用confirm
。 - 点击
编辑任务
操作后,右侧变更为编辑窗口。
- 第一行显示任务标题,对于未完成的任务,在标题行的右侧会有
- 新增及编辑任务窗口描述
- 有3个输入框:分别是标题输入框,完成日期输入框及内容输入框
- 标题输入框:输入标题,为单行,需要自行设定一个标题输入限制的规则(如字数),并给出良好提示。
- 日期输入框:单行输入框,按照要求格式输入日期,如yyyy-mm-dd
- 内容输入框:多行输入框,自行设定一个内容输入的限制(如字数),并给出良好提示。
- 确认按钮:确认新增或修改。
- 取消按钮:取消新增或修改。
任务实现要求:
- 整个界面的高度和宽度始终保持和浏览器窗口大小一致。当窗口变化高宽时,界面中的内容自适应变化。
- 左侧列表和中间列表保持一个固定宽度(自行设定),右侧自适应。
- 需要自行设定一个最小宽度和最小高度,当浏览器窗口小于最小值时,界面内容的高度和宽度不再跟随变化,允许浏览器出现滚动条。
- 通过本地存储来作为任务数据的保存方式。
- 不使用任何类库及框架。
- 尽可能符合代码规范的要求。
- 浏览器兼容性要求:Chrome、IE8+。
注意
该设计稿仅为线框原型示意图,所有的视觉设计不需要严格按照示意图。如果有设计能力的同学,欢迎实现得更加美观,如果没有,也可以按照线框图实现。以下内容可以自行发挥:
- 背景颜色
- 字体大小、颜色、行高
- 线框粗细、颜色
- 图标、图片
- 高宽、内外边距