发现一篇不错的博文,和大家分享一下,为有志成为一名优秀前端工程师的童鞋们提供一个参考。 :)~
本文来源:http://www.biaodianfu.com/what-makes-a-good-front-end-engineer.html
一、技术的必须的
作为一名最基础的前端工程师你必须掌握HTML、CSS和JavaScript。三者必须同时精通,类似我这样对前端知识一知半解的,一遇到问题就停下工作就四处搜索解决方案的,首先就算不上一个合格的前端人员。像我这样的如果当了前端工程师那工期肯定是不能保证的。合格的前端工程师第一要学会的就是在没有任何外来帮助的情况下(包括搜索引擎),能够完成大多数任务。
以下知识点是作为一个前端工程师必须了解和熟悉的:
-
DOM结构——两个节点之间可能存在哪些关系以及如何在节点之间任意移动。
-
DOM操作——怎样添加、移除、移动、复制、创建和查找节点。
-
事件——怎样使用事件以及IE和DOM事件模型之间存在哪些主要差别。
-
XMLHttpRequest——这是什么、怎样完整地执行一次GET请求、怎样检测错误。
-
严格模式与混杂模式——如何触发这两种模式,区分它们有何意义。
-
盒模型——外边距、内边距和边框之间的关系,IE < 8中的盒模型有什么不同。
-
块级元素与行内元素——怎么用CSS控制它们、它们怎样影响周围的元素以及你觉得应该如何定义它们的样式。
-
浮动元素——怎么使用它们、它们有什么问题以及怎么解决这些问题。
-
HTML与XHTML——二者有什么区别,你觉得应该使用哪一个并说出理由。
-
JSON——它是什么、为什么应该使用它、到底该怎么使用它,说出实现细节来。
上述这些知识点都应该是你“想都不用想”就知道的东西。除了上述的前端知识,也还需学会至少一门后端编程语言,让你自己学会如何与后端进行更好的交互。
很多前端工程师对一些库非常的熟悉,jQuery,Bootstrap等,但是对于库的熟悉并不能提现你的优秀,真正优秀的是那些理解库背后的机制,特别是能够徒手写出一个自己的库的人。
真正合格的前端工程师是能实现具体的功能要求,而优秀的前端工程师需要解决的问题是寻找一个最优的解决方案。
二、沟通很重要
优秀的前端工程师需要具备良好的沟通能力,因为你的工作与很多人的工作息息相关。在任何情况下,前端工程师至少都要满足下列四类客户的需求。
-
产品经理——这些是负责策划应用程序的一群人。他们能够想象出怎样通过应用程序来满足用户需求,以及怎样通过他们设计的模式赚到钱(但愿如此)。一般来说,这些人追求的是丰富的功能。
-
UI设计师——这些人负责应用程序的视觉设计和交互模拟。他们关心的是用户对什么敏感、交互的一贯性以及整体的好用性。他们热衷于流畅靓丽但并不容易实现的用户界面。
-
项目经理——这些人负责实际地运行和维护应用程序。项目管理的主要关注点,无外乎正常运行时间——应用程序始终正常可用的时间、性能和截止日期。项目经理追求的目标往往是尽量保持事情的简单化,以及不在升级更新时引入新问题。
-
最终用户——当然是应用程序的主要消费者。尽管我们不会经常与最终用户打交道,但他们的反馈意见至关重要;没人想用的应用程序毫无价值。最终用户要求最多的就是对个人有用的功能,以及竞争性产品所具备的功能。
不要在没有作出评估之前就随便接受某项任务。你必须始终记住,一定先搞清楚别人到底想让你干什么,不能简单地接受“这个功能有问题”之类的大概其的说法。而且,你还要确切地知道这个功能或设计的真正意图何在。“加一个按钮”之类的任务并不总意味着你最后会加一个按钮。还可能意味着你会找产品经理,问一问这个按钮有什么用处,然后再找UI设计师一块探讨按钮是不是最佳的交互手段。要成为优秀的前端工程师,这种沟通至关重要。
那么,前端工程师应该最关注哪些人的意见呢?答案是所有这四类人。优秀的前端工程师必须知道如何平衡这四类人的需求和预期,然后在此基础上拿出最佳解决方案。由于前端工程师处于与这四类人沟通的交汇点上,因此其沟通能力的重要性不言而喻。如果一个非常酷的新功能因为会影响前端性能,必须删繁就简,你怎么跟产品经理解释?再比如,假设某个设计如果不改回原方案可能会给应用程序造成负面影响,你怎么才能说服UI设计师?作为前端工程师,你必须了解每一类人的想法从何而来,必须能拿出所有各方都能接受的解决方案。从某种意义上说,优秀的前端工程师就像是一位大使,需要时刻抱着外交官的心态来应对每一天的工作。
专业技术可能会引领你进入成为前端工程师的大门,但只有运用该技术创造的应用程序以及你跟他人并肩协同的能力,才会真正让你变得优秀。
三、提升无止境
优秀的前端工程师应该具备快速学习能力。推动Web发展的技术并不是静止不动的,这些技术几乎每天都在变化,如果没有快速学习能力,你就跟不上Web发展的步伐。你必须不断提升自己,不断学习新技术、新模式;仅仅依靠今天的知识无法适应未来。Web的明天与今天必将有天壤之别,而你的工作就是要搞清楚如何通过自己的Web应用程序来体现这种翻天覆地的变化。
四、前端开发知识架构
- 前端工程师
- 浏览器
- 编程语言
- 切页面
- 开发工具
- 代码质量
- 前端库/框架
- 前端标准/规范
- HTTP1.1
- ECMAScript3/5
- W3C/DOM/BOM/XHTML/XML/JSON/JSONP
- CommonJS/AMD
- HTML5/CSS3
- 性能
- 编程知识储备
- 部署流程
- 代码组织
- 安全
- 移动Web
- JavaScript生态
- 前沿技术社区/会议
- 计算机知识储备
- 编译原理
- 计算机网络
- 操作系统
- 算法原理
- 软件工程/软件测试原理
- 软技能
- 知识管理/总结分享
- 沟通技巧/团队协作
- 需求管理/PM
- 交互设计/可用性/可访问性知识
- 可视化
- 后端工程师
- 编程语言
- C/C++/Java/PHP/Ruby/Python/…
- 数据库
- 操作系统
- 数据结构
参考链接:
http://www.cn-cuckoo.com/2010/01/10/nicholas-c-zakas-talk-about-what-makes-a-good-front-end-engineer-1356.html
https://github.com/jacksontian/fks
http://julying.com/blog/how-to-become-a-good-web-front-end-engineer/
分享到:
相关推荐
参考资料-1、IT-华建绩效管理制度.zip
华建打印安全监控与审计系统是一套打印安全审计系统,主要用于对局域网内打印行为的审计和控制任务
参考资料-093.钢构施工方案-华建管桩.zip
中建钢构施工方案-华建管桩(35P).rar
中建钢构施工方案-华建管桩(35P).doc
智慧企业总部楼宇解决方案-华为&华建数创.pdf
SSM+Vue项目实战-华建汽车出租系统的Java毕业设计(源码+说明+数据库).zip 【项目技术】 开发语言:Java 框架:ssm+vue 数据库:mysql 【实现功能】 主要的模块包括主界面,个人中心、客户信息管理、车辆信息管理、...
在知识经济时代,管理者需要一种全新的管理理念和管理手段对政府办公管理流程进行整合。华建集团OA-STAR政府办公自动化系统针对当前政府办公自动化建设的需求,实现了不同地理位置、不同单位或部门之间的协同办公。...
安卓应用-教育学习
华建集团:华建集团2021年半年度报告.PDF
在知识经济时代,管理者需要一种全新的管理理念和管理手段对政府办公管理流程进行整合。华建集团OA-STAR政府办公自动化系统针对当前政府办公自动化建设的需求,实现了不同地理位置、不同单位或部门之间的协同办公。...
华建网络大学校园网方案
华建社区接入网络的整个网络系统的主干网采用千兆以太网,网络综合布线采用光纤到楼宇,双绞线入户的方案。为了便于网络设备的维护和管理,需要设主交换中心机房一处。也可以根据网络的规模设立分中心机房。主交换...
网上审批是一种交互式办公方式,可以打破时间、空间和部门分隔的制约,将政府机构管理和服务职能,由传统手工、纸面、封闭的运作方式转换为自动、电子、开放的方式,在网络上加以实现。极大地提高政府管理工作的效率...
(内部资料,只列出一部分) 北京-ORACLE畅享互联科技.doc 北京-ORACLE海存量数据科技有限公司.doc 北京-ORACLE华鼎博士科技.doc 北京-ORACLE友空间信息技术有限公司.doc 北京-ORACLE中讯汉扬.doc 北京-SQL华建集团....
&华建集团-2020城市更新白皮书系列:历史文化街区的活化迭代-2020-68页.rar
华建集团:华建集团2021年半年度报告.rar
第一太平戴维斯&华建集团-2020城市更新白皮书系列:历史文化街区的活化迭代-2020-68页.pdf
华建控股:年报2019.PDF
华建存储网络系统通过在千兆以太网、TCP/IP、光纤通道和光网络上共享和扩展企业的SAN和网络附加存储(NAS)存储资源。通过IP与存储的融合,对存储资源使用网络安全、QoS、MPLS、三层交换、高速缓存和服务器负载平衡...