如何成为前端工程师?
前端技术的学习有两条路径:一个是“多线程”的学习路径,一个是深入学习的路径。什么是“多线程”的学习路径?
第一个线程,是基础知识的学习。这个是学习其它技术的基础。基础知识需要系统的学,基础包括JavaScript / HTML / CSS / 原生 Web API的学习。学过之后还不能直接做项目,你还需要掌握一些框架和工具才能解决问题,但如果要更好的解决问题、组合方案、调试问题,就必须对语言和语言特性有深入的理解。
第二个线程,领域知识的学习。前面也说过,要不断丰富自己的知识结构。特定的岗位需要特定的领域知识。会有一些通用性的知识,像软件工程 / 数据 & 算法 / 网络 / 可视化 / 安全 / 交互设计,这些知识和理论不要求有多深的学习,但要有一定的认知。
第三个线程,工程实践经验。重点是使用的经验。像开发工具 / 包管理 / 构建工具 / 主流的框架和库 / 代码版本管理 / 调试和测试相关工具等等,这些工具层面的东西,虽然比较多,很多达到会用的程度就可以。前端工具有“喜新厌旧”的特点,变化很快,要不断吸收最新的东西。所谓“善假于物”,善于使用开源的库和工具,能够帮助我们快速的解决问题。但是,如果不了解背后的原理、技术点,仅仅停留在会用的层面,只能是生搬硬套,很难有进一步提高。很多人说前端发展太快了,刚学会一个东西,过两年就被淘汰了,说的其实就是工具层面的东西,越基础的东西相对越稳定,也就越值得投入精力去学。工程方面,像React这种基础库相对稳定,值得深入的去学,后面我会讲怎么深入去学。实际上,任何新东西都有其发展的脉络,如果你具备一定基础,了解背后的原理,你不仅能很快掌握它,还能完善它。
要成为一名专业的前端工程师,需要多线程、多维度的学习,包括工作之后,仍然需要持续去学习。对同学们起步来说,基础要牢固,工程方面有一定的使用经验,知识结构要尽可能广泛和丰富。
学好 html css js
nodejs vuejs ...
先学好这些 能成为个初级前端工程师
一、技术的必须的
作为一名最基础的前端工程师你必须掌握HTML、CSS和JavaScript。三者必须同时精通,类似我字样对前端知识一知半解的,一遇到问题就停下工作就四处搜索解决方案的,首先就算不上一个合格的前端人员。像我这样的如果当了前端工程师那工期肯定是不能保证的。合格的前端工程师第一要学会的就是在没有任何外来帮助的情况下(包括搜索引擎),能够完成大多数任务。
以下知识点是作为一个前端工程师必须了解和熟悉的:
DOM结构——两个节点之间可能存在哪些关系以及如何在节点之间任意移动。
DOM操作——怎样添加、移除、移动、复制、创建和查找节点。
事件——怎样使用事件以及IE和DOM事件模型之间存在哪些主要差别。
XMLHttpRequest——这是什么、怎样完整地执行一次GET请求、怎样检测错误。
严格模式与混杂模式——如何触发这两种模式,区分它们有何意义。
盒模型——外边距、内边距和边框之间的关系,IE < 8中的盒模型有什么不同。
块级元素与行内元素——怎么用CSS控制它们、它们怎样影响周围的元素以及你觉得应该如何定义它们的样式。
浮动元素——怎么使用它们、它们有什么问题以及怎么解决这些问题。
HTML与XHTML——二者有什么区别,你觉得应该使用哪一个并说出理由。
JSON——它是什么、为什么应该使用它、到底该怎么使用它,说出实现细节来。
产品经理——这些是负责策划应用程序的一群人。他们能够想象出怎样通过应用程序来满足用户需求,以及怎样通过他们设计的模式赚到钱(但愿如此)。一般来说,这些人追求的是丰富的功能。
UI设计师——这些人负责应用程序的视觉设计和交互模拟。他们关心的是用户对什么敏感、交互的一贯性以及整体的好用性。他们热衷于流畅靓丽但并不容易实现的用户界面。
项目经理——这些人负责实际地运行和维护应用程序。项目管理的主要关注点,无外乎正常运行时间——应用程序始终正常可用的时间、性能和截止日期。项目经理追求的目标往往是尽量保持事情的简单化,以及不在升级更新时引入新问题。
最终用户——当然是应用程序的主要消费者。尽管我们不会经常与最终用户打交道,但他们的反馈意见至关重要;没人想用的应用程序毫无价值。最终用户要求最多的就是对个人有用的功能,以及竞争性产品所具备的功能。
前端工程师
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/…
编程语言
数据库
操作系统
数据结构
上述这些知识点都应该是你“想都不用想”就知道的东西。除了上述的前端知识,也还需学会至少一门后端编程语言,让你自己学会如何与后端进行更好的交互。
很多前端工程师对一些库非常的熟悉,jQuery,Bootstrap等,但是对于库的熟悉并不能提现你的优秀,整整优秀的是那些理解库背后的机制,特别是能够徒手写出一个自己的库的人。
真正合格的前端工程师是能实现具体的功能要求,而优秀的前端工程师需要解决的问题是寻找一个最优的解决方案。
二、沟通很重要
优秀的前端工程师需要具备良好的沟通能力,因为你的工作与很多人的工作息息相关。在任何情况下,前端工程师至少都要满足下列四类客户的需求。
不要在没有作出评估之前就随便接受某项任务。你必须始终记住,一定先搞清楚别人到底想让你干什么,不能简单地接受“这个功能有问题”之类的大概其的说法。而且,你还要确切地知道这个功能或设计的真正意图何在。“加一个按钮”之类的任务并不总意味着你最后会加一个按钮。还可能意味着你会找产品经理,问一问这个按钮有什么用处,然后再找UI设计师一块探讨按钮是不是最佳的交互手段。要成为优秀的前端工程师,这种沟通至关重要。
那么,前端工程师应该最关注哪些人的意见呢?答案是所有这四类人。优秀的前端工程师必须知道如何平衡这四类人的需求和预期,然后在此基础上拿出最佳解决方案。由于前端工程师处于与这四类人沟通的交汇点上,因此其沟通能力的重要性不言而喻。如果一个非常酷的新功能因为会影响前端性能,必须删繁就简,你怎么跟产品经理解释?再比如,假设某个设计如果不改回原方案可能会给应用程序造成负面影响,你怎么才能说服UI设计师?作为前端工程师,你必须了解每一类人的想法从何而来,必须能拿出所有各方都能接受的解决方案。从某种意义上说,优秀的前端工程师就像是一位大使,需要时刻抱着外交官的心态来应对每一天的工作。
专业技术可能会引领你进入成为前端工程师的大门,但只有运用该技术创造的应用程序以及你跟他人并肩协同的能力,才会真正让你变得优秀。
三、提升无止境
优秀的前端工程师应该具备快速学习能力。推动Web发展的技术并不是静止不动的,这些技术几乎每天都在变化,如果没有快速学习能力,你就跟不上Web发展的步伐。你必须不断提升自己,不断学习新技术、新模式;仅仅依靠今天的知识无法适应未来。Web的明天与今天必将有天壤之别,而你的工作就是要搞清楚如何通过自己的Web应用程序来体现这种翻天覆地的变化。
四、前端开发知识架构
参考链接:
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
如何成为一个优秀的Web前端开发工程师?
一个优秀的前端工程师必须能适应技术的发展,不断突破提升自己的能力,了解前端发展的趋势是必不可少的。
前端开发通过HTML,CSS及JavaScript以及衍生出来的各种技术、框架、解决方案,来实现互联网产品的用户界面交互。随着互联网技术发展,前端技术也在不断地更新。需要前端开发的场景也在不断延伸,从传统的网站,到移动端开发,再到各类可穿戴设备,前端开发的交互设计也从基本的鼠标键盘,到触屏,甚至感控,手势行为等等。不难发现前端的发展趋势正在从“单端向多端发展”、“界面正在从GUI向NUI演进”,VR / AR等相关技术也越来越成熟。
一、好奇心
为了了解前端发展趋势,一颗好奇心是必要的。可以多关注技术博主,技术新闻等获取新技术的信息,不能排斥新技术,保持好奇心,拓展知识面,可以帮助自己快速的查漏补缺,快速成长。
二、专注力
浅尝辄止收效甚微,所以还需要一定的专注力。这个专注力不仅是指对于当前使用的技术上,更指一些新的热门技术。尤其对于些前端老人来讲,接纳一门新技术是耗时耗力的,但互联网相关技术最大的特点就是更新快,如果固步自封,是不会进步和成长的。
三、合适的学习方法
新的技术层出不穷,想要都每一个都深入学习是不现实的,所以,优秀的开发者要创建自己的学习方法。无论通过什么方式学习,与已经融会贯通的技术做类比去学习往往是见效比较快的。可多写些博客记录自己的学习感悟,在技术社区经常和同行多沟通交流意见也能得到意想不到的收获。
四、避免广而泛
如果你是一个想要成为优秀工程师的前端开发者,请记住,前端工程师的成长需要一定时间跨度的经验积淀。“这个我也懂,那个我也知道......”,这种广而泛的技术面是远远不够的。一个前端工程师要踩过多少坑,才能称的上是一个专业的前端工程师。真正的优秀不是纸上谈兵没事靠着自己的实践一点一点积累来的。
要想成为一个前端工程师,首先还是要学习基础的前端技术,HTML,CSS,Javascript其次,要会使用起码一种编辑工具,比如hbuilder等另外,再掌握的一两个主流的前端库,如vue,bootstrap,angularjs最后,实战,从自己做个小程序开始,到实用的程序到完整的一个项目,逐步积累经验,必然能成为前端工程师。
要想成为一个前端工程师,首先还是要学习基础的前端技术,HTML,CSS,Javascript其次,要会使用起码一种编辑工具,比如hbuilder等另外,再掌握的一两个主流的前端库,如vue,bootstrap,angularjs最后,实战,从自己做个小程序开始,到实用的程序到完整的一个项目,逐步积累经验,必然能成为前端工程师。
要想成为一个前端工程师,首先还是要学习基础的前端技术,HTML,CSS,Javascript其次,要会使用起码一种编辑工具,比如hbuilder等另外,再掌握的一两个主流的前端库,如vue,bootstrap,angularjs最后,实战,从自己做个小程序开始,到实用的程序到完整的一个项目,逐步积累经验,必然能成为前端工程师。
怎么转行进入IT行业?
一、转行方式 IT行业的人员需求量还是比较大的,需要各种各样人才,外行想去的路子很多,做好准备,一定可以的。1、报个培训班 通过参加培训班系统掌握UI、Web前端、数据分析类技术,之后找一份相关工作不难,工资待遇也可以。当然IT行业的技术更新的相对比较快,所以持续学习和自学能力很重要。2、自学 ...
如何自学 Python
所以,我的心底深处一直都想变成这样的一位魔法师。今年的8月,刚好工作上想要开发一个基于微信的英语学习网站,借此机会,我决定好好学习一下编程。在此之前,我所有关于程序的知识仅仅来源于两部分,一是本科时期的C语言必修课,现在已经忘的一干二净,不过好歹我从中明白编程是怎么回事;第二部分是...
web前端的就业方向有哪些
据数据统计,未来五年我国信息化人才总需求高达1500万-2000万人。其中“网络工程”“UI设计”“Web前端”等人才的缺口最为突出,所以Web前端的市场需求很大。更有甚者目前不仅大型互联网公司相继成立了专属的Web前端部门,中小型公司和创业公司也急需专业的Web前端工程师。【点击测试我适不适合学设计】 IT...
UI设计和web前端学习哪个好?哪个比较有前景?
通过HTML,CSS及JavaScript以及衍生出来的各种技术、框架、解决方案,来实现互联网产品的用户界面交互。通俗一点来讲,前端就是客服,主要跟顾客(用户)交流。其实UI设计和前端的工作相辅相成的,按照项目流程,一般是UI设计师设计好产品界面,前端工程师通过编码实现界面。通俗来说,UI设计师好比服装设计师...
为什么整个互联网行业都缺前端工程师
现在,几乎整个互联网行业都缺前端工程师,不仅在刚起步的创业公司,上市公司乃至巨头,这个问题也一样存在。没错,优秀的前端工程师简直比大熊猫还稀少。每天,100offer的HR群都有人在吐槽招不到前端工程师。实话说对这些需求,Betty也无能为力,因为在供不应求的前端招聘市场上,优秀的前端工程师才是有话语权的那一方。
为什么整个互联网行业都缺前端工程师
内存管理,垃圾收集算法等等)换句话说,如果说精通HTML+CSS+JS,了解后端知识,只是60分的合格前端;那么要想成为受追捧、拿高薪的80分优秀前端,要对业务需求和、架构设计有真正的运用;而100分的顶级前端,则必须要能够兼顾技术和设计,更接近「以前端开发为主的全栈工程师」了。
Java和前端哪个好?
Java和前端还是有区别的:前端开发:课程相对简单,要精通JS,能熟练应用JQuery,懂CSS,能熟练运用这些知识,进行交互效果的开发。后期觉得能适应可以补充后端技能,成为现在热门的web全栈工程师。Java开发:课程难度相对较大,要会写Java代码,会写SQL语句,能做简单的数据库设计,会Spring和iBatis,懂一些...
web前端开发培训费用是多少
我觉得学习不要总是纠结于自学还是跟别人学,要从实用的角度来出发,如果你觉得自学,半年能学会那可以自学,如果你自学需要好几年,基本就是浪费时间,如果跟高手学习,能够几个月就学的明明白白,就可以去找工作,何乐不为呢?第三 前端工程师的知识体系。优秀的前端工程师只有具有扎实的基础知识和...
零基础学Java需要多久 小白学Java难吗
小白学java是可以的,至于难易程度取决于自己的学习态度,因为任何人学任何东西都是0基础,在学习的过程中查漏补缺,逐渐的成为熟手,高手,专家。其实零基础学java从来都不可怕,可怕的是没有凿山开路的决心。如果你的内心真的对IT行业感兴趣,对Java语言感兴趣,那么你就多鼓励自己,或者你可以根据多...
学习软件编程未来可以从事哪些岗位?
你能熟练使用编程,熟悉操作系统,你可以成为专职程序员,熟悉底层软件你还可以成为系统工程师。累肯定的,干什么工作不累,干公务员还得想着完成政绩。你能熟练使用Java,可以处理面向对象的企业型的应用开发,公司企业Web页面设计、INTERNET可视化软件开发及动画等,Web服务器手机上的Java+游戏开发等等。这个...
征航佳蓉: 一、熟练掌握HTML、CSS、JavaScript 用语义化的HTML标签配合CSS百分百还原设计稿,并使用JavaScript完成各种交互逻辑,这是前端的基本功.当然,如果你想掌握扎实的理论知识,除了通过教材、视频等渠道学习外,在学习过程中做大...
阿克陶县17058582207: 如何成为一名前端工程师 - ?
征航佳蓉: 好久没有码字了.看到知乎上有很多回答,但是我知道问这个问题的人都是新手,所以今天突然硬起来想写一下关于我的看法,仅针对编码型前端工程师.作为一名前端工程师(让我去掉优秀或资深这类形容词),必须要掌握的三样东西HTML,...
阿克陶县17058582207: 如何成为好的前端工程师 - ?
征航佳蓉: 我得说自己对应聘者们提出的大多数问题都相当失望.我希望听到一些对在Yahoo!工作充满激情的问题.在昨天的应聘者中,只有一个人的问题是我认为最好的,那个人问我:你觉得怎么才能成为优秀的前端工程师?我觉得很有必要把这个问...
阿克陶县17058582207: 如何成为一名更出色的web前端工程师 - ?
征航佳蓉: 一位好的Web前端开发工程师在知识体系上不但要有广度,还要有深度,因此有很多的大公司即便是出高薪也很难招聘到比较理想的前端开发工程师.现在说的重点是不在于讲解技术,而是更加测重于对技巧的讲解.技术非黑即白,只有对和错...
阿克陶县17058582207: 如何成为一名前端人员 - ?
征航佳蓉: 我真不知道我一个回答别人的问题竟然有那么多人遇到相同的问题,我贴出来,让你也参考一下,希望对你前端之路有帮助.我在前端界里面做了6年,可以这么说,我在厦门做前端的时候,那时候全国有前端这个职位的几乎为零,几乎看不到...
阿克陶县17058582207: 如何才能成为一名出色的WEB前端工程师 - ?
征航佳蓉: 1. 多写.很多问题都是积累得来的.写了,遇到了,才能去真正理解解决方案,才会随着自己的不断成长而有进步.别人问我为什么知道那么多 CSS 兼容解决方案,为什么一看就出的时候,我只能告诉他,我写了 20 几个 Wordpress 主题.-,-2...
阿克陶县17058582207: 如何成为一名优秀的前端工程师 - ?
征航佳蓉: 一、技术的必须的作为一名最基础的前端工程师你必须掌握HTML、CSS和JavaScript.三者必须同时精通,类似我这样对前端知识一知半解的,一遇到问题就停下工作就四处搜索解决方案的,首先就算不上一个合格的前端人员.像我这样的如...
阿克陶县17058582207: 怎样才能成为web前端开发工程师 - ?
征航佳蓉: 首先要感谢伟大的Web2.0概念、产品概念、用户体验概念、jQuery插件,是它们在中国日渐成熟才解放了一直以来姥姥不疼舅舅不爱的前端开发工程师们. 有没有发现从09年下半年到现在全中国的互联网公司都在招聘前端开发工程师?如果你...
阿克陶县17058582207: 怎样才能成为一名优秀的WEB前端工程师?需要掌握哪些专业技能?虚心求教! - ?
征航佳蓉: 成为一名优秀的web前端工程师,易龙天网认为需要具备如下四点专业技能:第一、必须熟练掌握基本的web前端技术,比如:css、js、html、jquery 等等.第二、必须掌握网站的性能优化、SEO、UE、服务器端、兼容性、存在的bug等.第三、学会用工具辅助开发.第四、有良好的代码规范编写习惯web前端的前景广阔,兴趣是最好的老师.加油!
阿克陶县17058582207: 怎样成为Web前端开发工程师? ?
征航佳蓉: 学习基本的互联网基础知识基本Web服务协议(HTTP,FTP,SMTP和POP3或IMAP4) Web服务器软件(Apache、Tomcat、Nginx等) 浏览器(Chrome、Firefox等) 电子邮件服务器和客户端软件 学习HTML和CSS如果将网站比作一个房子,HTML 类似网页的砖头结构,CSS 就是对房子进行装修的材料. 学习XML、JSON