纸上得来终觉浅,绝知此事要躬行。
不知从何时开始,看到很多人在博客上介绍自己造的轮子,也看到不少人评论:“切,又是个造轮子的!”。直到我读了司徒正美写的《JavaScript框架设计》,才发现造轮子真是个天大的坑,你造轮子踩的坑比你做项目踩的坑多得去了。
其实说到造轮子,我第一印象竟然想到了知乎三大软狗“温赵轮”之一的“轮子哥”,哈哈,其实在知乎上也有关于造轮子的讨论:程序员所说的“轮子”是什么东西?创造它有什么意义?
我对造轮子的理解是:明明知道做的没有前辈们做的好,却仍然要去做。比如:明明有一大堆优秀的JS库够你用,你还是要义无反顾地去开发自己的库,倔强!
其实仔细观察,你会发现“造轮子”在这个世界是出奇普遍的事情。一般创作性的活动,刚开始都是从临摹他人作品开始。就算不“造轮子”,也要收集一大堆“轮子”,作家有他的素材库,设计师有大量的icon和笔刷,普通的“码农”也有个 common.js
存放自己常用的函数。以前的程序员们,经常会为了做一个数据处理程序而自己开发一门编程语言。如:Charls Moore,他在美国国家天文台做射电望远镜数据提取程序时开发了Forth;高德纳为了让自己写的书排版漂亮点,写了Tex;DHH为了做网站写了Rails......如果连写一个控件都要百度或Google查找答案,那水平不容易提高。
造轮子如何提升编程能力呢?看过很多博客介绍程序员如何成长,提升编程能力。总结起来就是:
- 多读书,重基础
- 做项目,累经验
- 拜高人,勤学习
这些都是中肯的建议,你这么做一定可以提升你的编程能力。而造轮子呢,你会发现以上三点都涉及到了,考验你综合素质能力的时候到了。举个例子,我们做个 DatePicker
吧!不用提醒我,Github上有一大堆别人写的 DatePicker
,而且Bootstrap官网推荐的那个基于jQuery的 DateTimePicker
也是超级好用的。但其实我就是想造个轮子,用纯JS自己写一个,我该怎么做呢?一脸懵逼!
代码层面,你需要考虑如何根据当天时间生成当月的所有天数,以及切换到上个月或者下个月,你的数据如何更新,你的当月天数用个数组存放就够了吗?如何根据这些数据渲染出 DatePicker
界面,用户应该怎么使用它?如何发布到npm上去,或者通过bower来下载,这些都你都要考虑。做好之后你想能不能改改,让它也能在VueJS或者ReactJS中也能使用。也许还有用户向你反馈IE6下根本不能用,这个时候你是不是要考虑兼容IE6,如果是,该如何在IE6下做测试。也许会有新功能添加进来,但你担心修改过程中会影响到之前的功能,所以你是不是要加上单元测试,防止改坏代码。假如你做的不错,很多人用了,你是不是要考虑做个网页,介绍推广下自己写的 DatePicker
呢!
上面介绍的只是我想到的一部分,实际开发过程中,你会遇到很多你平时觉得很简单,但实际上做起来十分困难的事情,所以你会发现,造轮子是如何提高你的编程能力。我并不建议你在工作项目中造轮子(如果你的工作就是造轮子或者公司要求除外),毕竟大部分的公司都要求业务优先,快速上线。但是工作之余,造个轮子玩玩也是非常有趣的事情。
接下来的日子,我会不定期在博客分享我造的轮子以及造轮子的过程,与大家分享造轮子的乐趣,共同提升编程能力。