本人前大厂前端工程师,《javascript设计模式》作者张容铭,目前专注于前端方面的教学。
首先可以明确的是每个技术都有一定的时间累积,那么在这时间的累积下面,不同的人技术水平肯定不一样,那么对于大多数前端来说前端技术能力究竟差在哪里呢?
下面对每个程序员进行一个归类的总结初级程序员仅能完成简单模块和项目的开发工作,难以胜任复杂模块的开发。通常是入行不久,1 年及以下工作经验的同学。能力要求熟悉前端基础知识如HTML、JS、CSS 。
[if !supportLists]00001. [endif]能够使用一门MVVM 框架进行简单的业务开发。
[if !supportLists]00002. [endif]遇到复杂的组件和模块,会找现有的*使用。
[if !supportLists]00003. [endif]会使用百度、google 等检索工具搜索问题。
中级程序员(阿里p5)在必要的辅导或标准流程支持下,能独立负责一个子模块或者一个项目的具体任务,对及时性和准确性负责。通常是2-3 年工作经验的同学。能力要求除了前端基础知识外,熟悉计算机、网络等专业基础知识。
[if !supportLists]00001. [endif]熟练掌握工作中使用的技术栈开发业务。(除了MVVM 框架外,还能了解 webpack 的配置)。
[if !supportLists]00002. [endif]能了解一个需求从开发-上线整个生命周期,并对各个环节负责。
[if !supportLists]00003. [endif]具备基本的逻辑分析、问题分解、归纳总结等能力。
[if !supportLists]00004. [endif]了解基本的数据结构和算法,写代码较熟练。
[if !supportLists]00005. [endif]知道从靠谱的渠道去查找问题,在找不到合适*的时候,会造一些简单的*辅助业务开发。
高级程序员(阿里p6)具有独挡一面的能力,能够高质量完成工作,能把握一个系统/团队的整体实现,在推行过程中能提炼新的方法或方案,或对现有方案提出改进建议并被证明有效。通常是 3 年+ 工作经验的同学。能力要求具有独挡一面的能力,能高质量的完成模块级的工作。
[if !supportLists]00001. [endif]熟练掌握工作中使用的技术栈,并能了解它们的实现原理。
[if !supportLists]00002. [endif]能够在一个需求从开发-上线整个生命周期中找到痛点,并能使用技术的手段解决,提升效率。
[if !supportLists]00003. [endif]能在模块维度对问题或需求做出分析和拆解,并做出相对合理的实现方案。
[if !supportLists]00004. [endif]熟练掌握基础的数据结构和算法,代码符合规范,逻辑清晰。
[if !supportLists]00005. [endif]有较好的技术选型能力。
程序员的进化之路初级-> 中级通常在初级这个阶段,是进步空间最大的阶段,这个阶段是不存在天花板的。编码编码是初级阶段最需要经常做的事情,古话说孰能生巧,写代码也是同样的道理。
[if !supportLists]· [endif]写什么的样代码在公司要多做业务,尝试不同的业务,目标是让自己先成为一个熟练工。下班后也可以折腾点小项目做,可以选择自己感兴趣的内容,尝试自己实现一遍。
[if !supportLists]· [endif]如何写代码学会模仿,参考大牛的编码风格,照葫芦画瓢。如果公司有代码规范,跟随着公司的代码规范走,如果没有,参考业界规范,并用工具(如eslint)约束自己。 遇到一些不会写的,哪怕找到可以参考的代码,跟着抄一遍也行。
学习初级阶段是需要通过大量的学习来提升自己的能力。1.明确自己的学习目标 学习是为了提升能力,能让你胜任更复杂和有挑战的工作。
2.应该学习什么内容 前端基础,JS、CSS、HTML 反复学习。 工作中用到的一门前端 MVVM 框架。 了解一些广度知识,比如 HTTP、正则表达式、Web安全、性能优化、设计模式,数据结构和算法。
3.找到合适的学习方式看书+编码:购买经典的书籍阅读,并作为平时写码的参考工具,看书和编码是一个反复的过程,基本就是看书->编码->看书->编码循环个 3-4 次,这个过程就是在不断修炼内功。视频:慕课网的入门实战视频,根据自己的需求购买,要充分学习自己购买的每一个视频,认真的跟着老师学习一遍写一遍,遇到不懂的要积极提问,学习在于深入而不在于多。视频比书籍的好处在于更贴合实践,也更贴合公司业务,另外,课程的升级和更新也更加灵活。官网文档:学习每一个新的技术栈,入门最好的方式是通过它的文档学习,可以系统的过一遍文档,手敲它每一个示例。
4.花更多的学习时间 如果想比别人成长的快,就得花比别人更多的时间用来学习(这也是为什么不鼓励日常加班),尤其是初级这个阶段,成长曲线是非常快的。
5.知识沉淀 俗话说好记性不如烂笔头,可以养成写博客的习惯,把学习的内容用文字的形式记录下来,整理成文,并按学习的技术方向做归类。
提问在初级阶段,免不了经常遇到问题,会提问也是一门技术活,好的提问姿势能让你事半功倍。1.好的提问方式首先你在提问之前,自己应该经过充分的思考,并学会把问题拆解,在拆解的过程中就会把问题的复杂度降低。其次要善用搜索引擎,把关键字提取出来去搜索引擎上去搜索,先尝试自己去解决问题。如果仍然不能解决,可以将问题的相关上下文、截图及必要标识及自己的思考过程、查找到的相关资料,以及自己的分析发送给想要帮助你的人,并能提供最小化复现的问题。最后,请将你的问题及解决方案重新整理,并告知帮助你的人问题已经解决,重新整理解决问题的过程会帮助你理清思路、从而对问题有着更深的理解。
中级-> 高级到了中级阶段,基本上意味着你可以在大公司缺人的时候进入大公司工作了,如果想成为大公司不可拒绝的人才,那你还需要朝着高级阶段努力。编码没错,到了中级阶段,你想要提升最重要的途径还是要编码。
1.写什么的样代码和初级不同,除了做业务之外,你也参与开发做一些偏技术类型的项目,比如参与组内组件库的开发,一些通用JSSDK 的开发,这些会对你的技术要求会更高。有机会去参与平时使用到的一些开源技术栈的共建,比如想实现每个feature 但现有开源库不满足,实现难度不大的情况下可以去提一个 pull request。
2.如何写代码学会模仿,除了参考大牛的编码风格,还要琢磨他们的编码思路,多思考他们为什么这么做。学会组件化、模块化的开发方式,学会复用和封装,减少CV 的操作。对自己的代码质量负责,可以经常组织code review。
工作想要进阶,需要在工作方面有些产出。1.业务思考要明白业务和公司的目标,参与到需求的早期阶段中,同时也要多思考业务,想着有没有通过技术手段来提升业务价值,比如移动端的白屏时间减少,可以带来很好的用户体验,提升用户的留存率。
2.技术思考思考业务开发中的一些痛点,如何用技术手段去优化业务的开发流程,提升开发效率,比如为业务量身定制一款脚手架工具。
3.优化工作流程不仅要熟悉从需求-开发-联调-测试-上线的每个工作环节,还要多思考每个环节有没有可以提升的点,特别是上线过程,比如能不能做到自动化,能不能做到小流量上线,能不能及时回滚代码。
4.技术分享把工作中遇到的一些问题的解决方案、学习的一些新技术,产出的一些技术项目总结下来,作为组内技术分享和输出,这样一是可以总结沉淀你的技术,二是可以让大家能知道你做的东西,并活跃组内的技术氛围,三是锻炼自己的表述能力,这个能力在大公司的晋升述职中非常重要。
学习中级阶段仍然需要通过大量的学习来提升自己的能力。
1.明确自己的学习目标学习是为了提升自己的硬实力,不仅仅能够提升工作效率,还能让自己更好的服务于业务,升职加薪。
2.应该学习什么内容研究工作中所用到的工具链,不仅仅是运行时的MVVM 框架,还可以是编译时的 webpack,必要的时候去研究其中的源码实现。深入学习一些广度知识,比如HTTP、正则表达式、Web安全、性能优化、设计模式,数据结构和算法,并把它们应用到你的工作中。
3.找到合适的学习方式看书:找到所学习方向的经典书籍阅读,适当做一些学习笔记。视频:如慕课网的进阶实战视频,根据自己的需求购买。官网文档:可以尝试去看一下英文文档。社区:*、HackerNews,慕课网手记、掘金等,除了利用碎片化时间看一些高质量文章学习,也可以往上面发布一些优质文章。GitHub:关注 trending,参与开源社区的共建,并尝试自己造一些*。
4.学习时间与深度在中级阶段,你仍然需要花很多时间去学习,这个时候要注重自己学习的深度了。
5.知识沉淀俗话说好记性不如烂笔头,可以养成写博客的习惯,把工作中深入学习到的一些非敏感知识记录下来并发布,而不仅仅去发布一些基础知识的学习了。
6.技术视野除了自己工作中的使用的技术栈之外,也要了解同类其它优秀的开源技术栈,从多个维度(feature 完整性、文档、上手难度、维护力度、生态等)去做对比。要保持对新技术的敏感的关注,并时刻思考这些技术能否为自己的业务带来价值,在需要的时候做合理的技术选型。
总结所谓技术能力其实就是解决问题的能力和学习能力,所以无论你在哪个阶段,甚至是更高的阶段,不断提升这两个能力都是你应该一直要做的事情。
需要前端视频的朋友可以及时加我的主页联系方式进行咨询
————————————————
版权声明:本文为CSDN博主「大厂前端工程师」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/webicketang/article/details/104182672