如何成为前端工程师?

author author     2023-03-22     437

关键词:

如何成为前端工程师?

一、技术的必须的

作为一名最基础的前端工程师你必须掌握HTML、CSS和JavaScript。三者必须同时精通,类似我字样对前端知识一知半解的,一遇到问题就停下工作就四处搜索解决方案的,首先就算不上一个合格的前端人员。像我这样的如果当了前端工程师那工期肯定是不能保证的。合格的前端工程师第一要学会的就是在没有任何外来帮助的情况下(包括搜索引擎),能够完成大多数任务。

以下知识点是作为一个前端工程师必须了解和熟悉的:

    DOM结构——两个节点之间可能存在哪些关系以及如何在节点之间任意移动。

    DOM操作——怎样添加、移除、移动、复制、创建和查找节点。

    事件——怎样使用事件以及IE和DOM事件模型之间存在哪些主要差别。

    XMLHttpRequest——这是什么、怎样完整地执行一次GET请求、怎样检测错误。

    严格模式与混杂模式——如何触发这两种模式,区分它们有何意义。

    盒模型——外边距、内边距和边框之间的关系,IE < 8中的盒模型有什么不同。

    块级元素与行内元素——怎么用CSS控制它们、它们怎样影响周围的元素以及你觉得应该如何定义它们的样式。

    浮动元素——怎么使用它们、它们有什么问题以及怎么解决这些问题。

    HTML与XHTML——二者有什么区别,你觉得应该使用哪一个并说出理由。

    JSON——它是什么、为什么应该使用它、到底该怎么使用它,说出实现细节来。

    上述这些知识点都应该是你“想都不用想”就知道的东西。除了上述的前端知识,也还需学会至少一门后端编程语言,让你自己学会如何与后端进行更好的交互。

    很多前端工程师对一些库非常的熟悉,jQuery,Bootstrap等,但是对于库的熟悉并不能提现你的优秀,整整优秀的是那些理解库背后的机制,特别是能够徒手写出一个自己的库的人。

    真正合格的前端工程师是能实现具体的功能要求,而优秀的前端工程师需要解决的问题是寻找一个最优的解决方案。

    二、沟通很重要

    优秀的前端工程师需要具备良好的沟通能力,因为你的工作与很多人的工作息息相关。在任何情况下,前端工程师至少都要满足下列四类客户的需求。

    产品经理——这些是负责策划应用程序的一群人。他们能够想象出怎样通过应用程序来满足用户需求,以及怎样通过他们设计的模式赚到钱(但愿如此)。一般来说,这些人追求的是丰富的功能。

    UI设计师——这些人负责应用程序的视觉设计和交互模拟。他们关心的是用户对什么敏感、交互的一贯性以及整体的好用性。他们热衷于流畅靓丽但并不容易实现的用户界面。

    项目经理——这些人负责实际地运行和维护应用程序。项目管理的主要关注点,无外乎正常运行时间——应用程序始终正常可用的时间、性能和截止日期。项目经理追求的目标往往是尽量保持事情的简单化,以及不在升级更新时引入新问题。

    最终用户——当然是应用程序的主要消费者。尽管我们不会经常与最终用户打交道,但他们的反馈意见至关重要;没人想用的应用程序毫无价值。最终用户要求最多的就是对个人有用的功能,以及竞争性产品所具备的功能。

    不要在没有作出评估之前就随便接受某项任务。你必须始终记住,一定先搞清楚别人到底想让你干什么,不能简单地接受“这个功能有问题”之类的大概其的说法。而且,你还要确切地知道这个功能或设计的真正意图何在。“加一个按钮”之类的任务并不总意味着你最后会加一个按钮。还可能意味着你会找产品经理,问一问这个按钮有什么用处,然后再找UI设计师一块探讨按钮是不是最佳的交互手段。要成为优秀的前端工程师,这种沟通至关重要。

    那么,前端工程师应该最关注哪些人的意见呢?答案是所有这四类人。优秀的前端工程师必须知道如何平衡这四类人的需求和预期,然后在此基础上拿出最佳解决方案。由于前端工程师处于与这四类人沟通的交汇点上,因此其沟通能力的重要性不言而喻。如果一个非常酷的新功能因为会影响前端性能,必须删繁就简,你怎么跟产品经理解释?再比如,假设某个设计如果不改回原方案可能会给应用程序造成负面影响,你怎么才能说服UI设计师?作为前端工程师,你必须了解每一类人的想法从何而来,必须能拿出所有各方都能接受的解决方案。从某种意义上说,优秀的前端工程师就像是一位大使,需要时刻抱着外交官的心态来应对每一天的工作。

    专业技术可能会引领你进入成为前端工程师的大门,但只有运用该技术创造的应用程序以及你跟他人并肩协同的能力,才会真正让你变得优秀。

    三、提升无止境

    优秀的前端工程师应该具备快速学习能力。推动Web发展的技术并不是静止不动的,这些技术几乎每天都在变化,如果没有快速学习能力,你就跟不上Web发展的步伐。你必须不断提升自己,不断学习新技术、新模式;仅仅依靠今天的知识无法适应未来。Web的明天与今天必将有天壤之别,而你的工作就是要搞清楚如何通过自己的Web应用程序来体现这种翻天覆地的变化。

    四、前端开发知识架构

    前端工程师

    SVG/Canvas/VML

    D3/Raphaël/DataV

    知识管理/总结分享

    沟通技巧/团队协作

    需求管理/PM

    交互设计/可用性/可访问性知识

    编译原理

    计算机网络

    操作系统

    算法原理

    软件工程/软件测试原理

    D2/WebRebuild

    NodeParty/W3CTech/HTML5梦工厂

    JSConf/沪JS(JSConf.cn)

    QCon/Velocity/SDCC

    JSConf/NodeConf

    YDN/YUIConf

    MongoDB/CouchDB

    HTML5/CSS3

    响应式设计

    Zeptojs/iScroll

    V5/Sencha Touch

    PhoneGap

    jQuery Mobile

    CSRF/XSS

    ADsafe/Caja/Sandbox

    类库模块化

    业务逻辑模块化

    文件加载

    CommonJS/AMD

    YUI3模块

    LABjs

    SeaJS/Require.js

    压缩合并

    文档输出

    项目构建工具

    YUI Compressor

    Google Clousure Complier

    CleanCSS/UglifyJS

    JSDoc

    Dox/Doxmate

    make/Ant

    GYP

    Grunt

    Yeoman

    数据结构

    OOP/AOP

    原型链/作用域链

    闭包

    函数式编程

    设计模式

    Javascript Tips

    JSPerf

    YSlow 35 rules

    PageSpeed

    HTTPWatch

    DynaTrace’s Ajax

    高性能JavaScript

    HTTP1.1

    ECMAScript3/5

    W3C/DOM/BOM/XHTML/XML/JSON/JSONP

    CommonJS/AMD

    HTML5/CSS3

    jQuery/Underscore/Mootools/Prototype.js

    YUI3/Dojo/ExtJS

    Backbone/KnockoutJS/Emberjs

    Coding style

    单元测试

    自动化测试

    JSLint/JSHint

    CSSLint

    Markup Validation Service

    QUnit/Jasmine

    Mocha/Should/Chai

    WebDriver

    IDE

    调试工具

    版本管理

    VIM/Sublime Text2

    Notepad++/EditPlus

    WebStorm

    Firebug/Firecookie

    YSlow

    IEDeveloperToolbar/IETester

    Fiddler

    Git/SVN

    Github/Bitbucket/Google Code

    HTML/HTML5

    CSS/CSS3

    PhotoShop/Paint.net

    JavaScript/Node.js

    JavaScript语言精粹

    IE6/7/8/9

    Firefox

    Chrome/Safari/Opera

    浏览器

    编程语言

    切页面

    开发工具

    代码质量

    前端库/框架

    前端标准/规范

    性能

    编程知识储备

    部署流程

    代码组织

    安全

    移动Web

    JavaScript生态

    前沿技术社区/会议

    计算机知识储备

    软技能

    可视化

    后端工程师

    Unix/Linux/OS X/Windows

    SQL

    MySQL/MongoDB/Oracle

    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

    JacksonTian/fks · GitHub

参考技术A 如何成为一个优秀的Web前端开发工程师?
一个优秀的前端工程师必须能适应技术的发展,不断突破提升自己的能力,了解前端发展的趋势是必不可少的。
前端开发通过HTML,CSS及JavaScript以及衍生出来的各种技术、框架、解决方案,来实现互联网产品的用户界面交互。随着互联网技术发展,前端技术也在不断地更新。需要前端开发的场景也在不断延伸,从传统的网站,到移动端开发,再到各类可穿戴设备,前端开发的交互设计也从基本的鼠标键盘,到触屏,甚至感控,手势行为等等。不难发现前端的发展趋势正在从“单端向多端发展”、“界面正在从GUI向NUI演进”,VR / AR等相关技术也越来越成熟。

一、好奇心
为了了解前端发展趋势,一颗好奇心是必要的。可以多关注技术博主,技术新闻等获取新技术的信息,不能排斥新技术,保持好奇心,拓展知识面,可以帮助自己快速的查漏补缺,快速成长。

二、专注力
浅尝辄止收效甚微,所以还需要一定的专注力。这个专注力不仅是指对于当前使用的技术上,更指一些新的热门技术。尤其对于些前端老人来讲,接纳一门新技术是耗时耗力的,但互联网相关技术最大的特点就是更新快,如果固步自封,是不会进步和成长的。

三、合适的学习方法
新的技术层出不穷,想要都每一个都深入学习是不现实的,所以,优秀的开发者要创建自己的学习方法。无论通过什么方式学习,与已经融会贯通的技术做类比去学习往往是见效比较快的。可多写些博客记录自己的学习感悟,在技术社区经常和同行多沟通交流意见也能得到意想不到的收获。

四、避免广而泛
如果你是一个想要成为优秀工程师的前端开发者,请记住,前端工程师的成长需要一定时间跨度的经验积淀。“这个我也懂,那个我也知道......”,这种广而泛的技术面是远远不够的。一个前端工程师要踩过多少坑,才能称的上是一个专业的前端工程师。真正的优秀不是纸上谈兵没事靠着自己的实践一点一点积累来的。
参考技术B 要想成为一个前端工程师,首先还是要学习基础的前端技术,HTML,CSS,Javascript其次,要会使用起码一种编辑工具,比如hbuilder等另外,再掌握的一两个主流的前端库,如vue,bootstrap,angularjs最后,实战,从自己做个小程序开始,到实用的程序到完整的一个项目,逐步积累经验,必然能成为前端工程师。 参考技术C 要想成为一个前端工程师,首先还是要学习基础的前端技术,HTML,CSS,Javascript其次,要会使用起码一种编辑工具,比如hbuilder等另外,再掌握的一两个主流的前端库,如vue,bootstrap,angularjs最后,实战,从自己做个小程序开始,到实用的程序到完整的一个项目,逐步积累经验,必然能成为前端工程师。 参考技术D 要想成为一个前端工程师,首先还是要学习基础的前端技术,HTML,CSS,Javascript其次,要会使用起码一种编辑工具,比如hbuilder等另外,再掌握的一两个主流的前端库,如vue,bootstrap,angularjs最后,实战,从自己做个小程序开始,到实用的程序到完整的一个项目,逐步积累经验,必然能成为前端工程师。

如何成为一个优秀的前端工程师?

一、英语。由于大部分优秀的新技术几乎都来源于欧美国家,因此依赖官方的汉化资料往往需要等待很长的时间。等中文资料已经满大街了,同时可能表明这种技术已经过时了。因此流程阅读英文材料必须作为一个优秀程序员的... 查看详情

如何自学成为一个web前端

...来说就是做网页的,我们上网浏览的网站界面就是WEB前端工程师做的。  在互联网迅速发展的近几年,你上网冲浪的时候是不是感觉WEB网站越来越漂亮酷炫,功能越来越多,越来越复杂?各种类似桌面软件的Web应用大量出现,... 查看详情

2019年如何成为全栈工程师?

2019年到了,每个前端工程师都有一颗全栈的心,很多读者私信我,怎么才能晋升为全栈工程师。这里给大家解答一下大概路线。随着前端能做的事情越来越多,前端的知识体系也越来越复杂,面对密集的知识点,一口气吃不成... 查看详情

作为一个web前端工程师,要不断的深入自己的技能

现在,前端工程师终于前所未有的在Web中占有了一席之地。随着多设备、浏览器和Web标准的演变革命,前端正在成为兼顾逻辑、性能、交互、体验的综合性岗位。虽然现在互联网行业普遍缺少Web前端工程师,但是我们相信越来越... 查看详情

怎样成为优秀的后端工程师

...engineer-9da75202a104让我们一起看看国外开发者认为优秀后端工程师需要掌握哪些技能。谁是后端工程师?本质上,软件开发有两个要素:前端和后端。当访问者登陆网站时,他们会看到UI与之交互,即前端。前端与用户交互,收集... 查看详情

如何成为一名ai工程师

如何成为一名AI工程师step前端:js,html,找准方向开始累积知识!计算机/数学专业pythonanacondaIDEpycharm/jupyter熟悉基础语法,了解数据结构刷leetcode,剑指offer熟悉基础数学知识机器学习入门概念监督学习=分类模型半监督学习无监... 查看详情

前端工程化浅析

...搭建环境以及搞笑的代码管理,后期处理成为了衡量前端工程师技术的标准 &n 查看详情

markdown如何成为软件工程师(代码片段)

查看详情

如何成为一名大数据工程师?

未来,对熟练的大数据工程师的需求将急速增长。现实的情况是这样的,无论公司属于哪个行业,要想在当今竞争激烈的市场环境中取得成功,需要一个强大的软件架构用来存储和访问公司数据,最好从公司创立一开始就要搭建... 查看详情

如何成为python工程师?科技大佬说,只需做好这五个点即可

现在python是越来越火了,如何成为python工程师?这也成了很多初学者的疑问。似乎学了很久,学了很多,依然离python工程师有不小的距离,那么非科班出身的我们,到底该如何成为python工程师呢?首先如果你希望成为专业的程序... 查看详情

如何成为python工程师?科技大佬说,只需做好这五个点即可

现在python是越来越火了,如何成为python工程师?这也成了很多初学者的疑问。似乎学了很久,学了很多,依然离python工程师有不小的距离,那么非科班出身的我们,到底该如何成为python工程师呢?首先如果你希望成为专业的程序... 查看详情

前端开发需要学习什么?需要掌握哪些技能?

...发领域开始变得非常困难,那想要成为一名前端开发工程师,前端开发需要学习什么呢?在这篇文章中,为你总结了如何成为前端开发人员的10个技巧!以及前端学习路线,欢迎参考!前端开发需要学... 查看详情

前端开发需要学习什么?需要掌握哪些技能?

...发领域开始变得非常困难,那想要成为一名前端开发工程师,前端开发需要学习什么呢?在这篇文章中,为你总结了如何成为前端开发人员的10个技巧!以及前端学习路线,欢迎参考!前端开发需要学... 查看详情

如何成为一个大数据工程师?学习路线图是什么?

...的路上很迷茫,不知道该如何成为一名合格的大数据开发工程师,也不知道该学习哪些技术,下面就给大家谈谈如何成为一个大数据开发工程师!想要成为大数据工程师,首先要更新自己的技术库,也就是说需要将自己以前学习... 查看详情

如何成为合格的软件工程师

...软件开发团队里,首先要确保团队里的成员是合格的软件工程师。那么该如何成为一名合格的软件工程师呢?这是我们要考虑和学习的。为此,我们需要先了解一些基本概念和技术。   既然是一个开发团队,那么绝大... 查看详情

typescript前端工程最佳实践

...工程化的快速发展,TypeScript变得越来越受欢迎,它已经成为前端开发人员必备技能。TypeScript最初是由微软开发并开源的一种编程语言,自2012年10月发布首个公开版本以来,它已得到了人们的广泛认可。TypeScript发展至今,已经成... 查看详情

大前端的前景如何

...项目的发展,用户对于用户体验的需求不断提升,Web前端工程师逐渐成为介于视觉工程师和后端工程师之间必不可少的角色,备受大家的追捧和关注。前端要学的主要内容:①计算机基础以及PS基础②前端开发基础(HTML5开发、Ja... 查看详情

如何成为当下一个合格的算法工程师

如何成为当下一个合格的算法工程师知乎上看了SimonS大神的一个live做了一些笔记一,Q&A部分:1.一个特征分析的例子。。。(听不懂)2.还是一个机器学习的例子,(听不懂)大致,降低复杂度... 查看详情