任务二十八:行星与飞船(三)

面向人群:
有一定JavaScript基础,希望学习或加强面向对象编程及设计模式相关知识的同学
难度:
中等

重要说明

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

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

任务目的

  • 练习JavaScript面向对象设计
  • 实践一些基础的设计模式

任务描述

  • 基于任务二十七,我们继续改善
  • 第二代宇宙飞船系统进步了很多,但是我们依然无法知道飞船的能源消耗情况,可能有的时候我们发出开始飞行的指令,但飞船早就没有能量了,所以我们再次进行升级,这次我们需要增加一个飞船状态的监视系统
  • 我们为每个飞船增加一个信号发射器,飞船会通过BUS系统定时(比如每秒)广播自己的飞行状态。发送的时候,我们通过已经安装在飞船上的Adapter把状态数据翻译成二进制码形式,把飞船自身标示,飞行状态,能量编码成一个16位的二进制串,前四位用于飞船自身标示,接下来4位表示飞行状态,0010为停止,0001为飞行,1100表示即将销毁,后八位用于记录飞船剩余能源百分比
  • 行星上有一个信号接收器,用于通过BUS系统接受各个飞船发送过来的信号
  • 当信号接收器接收到飞船信号后,会把信息传给数据处理中心(DC),数据处理中心依然是调用Adapter模块,把这些二进制数据转为对象格式存储在DC中
  • 实现一个行星上的监视大屏幕(如图),用来显示所有飞船的飞行状态及能源情况,当数据处理中心飞船数据发生变化时,它会相应在监视器上做出变化

任务注意事项

  • 实现功能的同时,请仔细学习JavaScript相关的知识
  • 相关信息发送、接受等,建议在控制台中输出
  • 实现各种功能、模块时,不需要生搬硬套设计模式,但希望你就设计模式相关知识进行学习,并进行合理的借鉴运用
  • 任务说明中的各种数值说明只是参考,可能存在不合理性,可以自行设定
  • 请注意代码风格的整齐、优雅
  • 代码中含有必要的注释
  • 允许使用jQuery等库,但不建议使用React、Angular等框架

任务协作建议

  • 如果是各自工作,可以按以下方式:
    • 团队集中讨论,明确题目要求,保证队伍各自对题目要求认知一致
    • 各自完成任务实践
    • 交叉互相Review其他人的代码,建议每个人至少看一个同组队友的代码
    • 相互讨论,最后合成一份组内最佳代码进行提交
  • 如果是分工工作(推荐),可以按以下模块切分
    • 飞船发射器
    • Adapter调整
    • 数据处理中心
    • 监视大屏幕

在线学习参考资料

posted @ 2016-03-24 21:18  huansky  阅读(207)  评论(0编辑  收藏  举报