任务四十:UI组件之日历组件(一)

面向人群:
有一定基础的同学
难度:

重要说明

百度前端技术学院的课程任务是由百度前端工程师专为对前端不同掌握程度的同学设计。我们尽力保证课程内容的质量以及学习难度的合理性,但即使如此,真正决定课程效果的,还是你的每一次思考和实践。

课程多数题目的解决方案都不是唯一的,这和我们在实际工作中的情况也是一致的。因此,我们的要求不仅仅是实现设计稿的效果,更是要多去思考不同的解决方案,评估不同方案的优劣,然后使用在该场景下最优雅的方式去实现。那些最终没有被我们采纳的方案,同样也可以帮助我们学到很多知识。所以,我们列出的参考资料未必是实现需求所必须的。有的时候,实现题目的要求很简单,甚至参考资料里就有,但是背后的思考和亲手去实践却是任务最关键的一部分。在学习这些资料时,要多思考,多提问,多质疑。相信通过和小伙伴们的交流,能让你的学习事半功倍。

任务目的

  • 练习综合运用HTML、CSS、JavaScript实现局部功能
  • 练习对于代码的抽象与封装
  • 为第四阶段的RIA任务做准备

任务描述

  • 如下示例图中所示的各种日历组件,参考并实现一个日历选择组件
  • 组件默认一直呈显示状态
  • 通过某种方式选择年、月,选择了年月后,日期列表做相应切换
  • 通过单击某个具体的日期进行日期选择
  • 组件初始化时,可配置可选日期的上下限。可选日期和不可选日期需要有样式上的区别
  • 提供设定日期的接口,指定具体日期,日历面板相应日期选中
  • 提供获取日期的接口,获取日历面板中当前选中的日期,返回一个日期对象(或其他形式,自定)

任务注意事项

  • 示例图仅为参考,样式及交互方式不需要完全实现一致
  • 可以使用JQuery等类库,不可直接使用现成的日历组件
  • 请注意代码风格的整齐、优雅
  • 代码中含有必要的注释

任务协作建议

  • 可同时做40,41,42,按任务分配
  • 团队集中讨论,明确题目要求,保证队伍各自对题目要求认知一致
  • 各自完成任务实践
  • 交叉互相Review其他人的代码,建议每个人至少看一个同组队友的代码
  • 相互讨论,最后合成一份组内最佳代码进行提交
posted @ 2016-04-21 11:19  huansky  阅读(555)  评论(0编辑  收藏  举报