面对复杂功能, js怎么写的有条理
假如给你一个复杂的功能让你实现,有什么思路写好这个功能?
该功能包括获取ajax数据,渲染数据,与其他dom交互,自身的css样式改变等等
怎么写条理清晰,该复用的能复用,而且容易让别人看懂。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
假如给你一个复杂的功能让你实现,有什么思路写好这个功能?
该功能包括获取ajax数据,渲染数据,与其他dom交互,自身的css样式改变等等
怎么写条理清晰,该复用的能复用,而且容易让别人看懂。
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(7)
这个问题,几年前我也问过,当时并没有得到很好的答案。
给你一个抽象的回答就是六大原则,给你一个具体可执行的回答就是写海量的代码。
而且这必然是一个长期的过程,一夜间打通任督的情况,基本不会发生。
尝试使用 波利亚的四步解题法 解答一下:
彻底理解问题
解决问题之前需要理解问题,找出问题的主干:
形成解决思路
根据以往的经验、或者已经掌握的技能和知识构建解决问题的思路。
软件开发的各种设计模式和设计原则都是解决类似问题的基本经验。
执行
按照自己的解题思路,耐心的执行。
软件开发过程可以方便的获取结果的反馈,所以可以在执行的过程中不断的调整。
总结
每次解决完问题,需要把整个过程重新思考总结一下,获取会发现更好的解决方法。
总结整理形成自己实现功能的基本套路,下次遇到类似问题就可以进一步的精进了。
解决复杂问题的关键在于第一 二步,能够高效持续的解决问题的关键在于第三步和第四步。
好像回答了,但又没有完全回答。
重新审视一下问题:
那么就需要了解是什么样的功能?为什么复杂?
什么样的功能?
一个功能的核心是需要解决用户的实际问题。
由此需要了解这个功能的用户是谁?问题的背景是什么?实际问题是什么?功能所处理的对象是什么?功能的核心逻辑是什么?等等
如果能够套用5W1H的问题模板,就可以充分的了解这个功能是什么。
为什么复杂?
功能的复杂程度往往来自于功能的抽象程度,越是抽象的问题,拆解问题的层次就越丰富,解决问题的方法就越多。
从用户界面到核心数据,越是复杂的功能,就有越多中间的逻辑层。
对于程序员来说,构建抽象层次的能力基本就等于解决复杂问题的能力。
经典的设计模式、设计原则以及各种各样的思维模型都是拆解复杂的基本套路。
如何写好这个功能?
实现的方法要与思考的方法恰恰相反,从底层出发,首先设计数据模型,然后构建数据处理逻辑,再在这个基础上搭建上层建筑,填充样式。
简单的说,就是自顶而下的设计,自底向上的实现,核心不过是抽象和分层。
JS:
CSS:
Ajax:
其他的不多说了。
楼主问的是设计问题, 其实是个预测未来的问题, 即未来
你预测的越准, 你的设计就越有效
其次是设计方法 技巧, 各种创建型模式, 观察者模式, 所有24设计模式, 依赖注入, 控制反转, Actor模型....
设计方法 技巧的形式是永远说不完的, 基本逻辑都必须依赖前一步骤对未来的预测, 将变化的地方抽取出来, 将不变的部分设计成框架/约束
你在每个能更高内聚低耦合的地方都做好了。就会量变变成质变。但是在达到质变的点之前,你都会感到迷茫不知道怎么才能写好代码。
其实你已经做到了,只要坚持学习更多小技巧,运用起来,直到发生质变
看我这篇文章 不用谢。
https://segmentfault.com/a/11...
量变 -> 质变