前端工程师的知识体系

产图是前者工程师图解:

图片 1

7e7ec141gdf7d4810f25f&690

 

前端开发的核心是HTML + CSS +
JavaScript。本质上它们组成一个MVC框架,即HTML作为信息模型(Model),CSS控制样式(View),JavaScript负责调度数据以及兑现某种展现逻辑(Controller)。

HTML


1.标签的分类

  • 签表示一个素

  • 依照性质划分: Block-Level和Inline-Level

  • 遵照语义划分:

Headings: h1, h2, h3, h4, h5, h6
Paragraphs: p
Text Formatting: em, strong, sub, del, ins, small
Lists: ul, li, ol, dl, dt, dd
Tables: table, thead, tbody, tr, th, td
Forms and Input: form, input, select, textarea
Others: div, span, a, img,
HTML5: header, footer, article, section

2.XHTML
XHTML 于2000年的1月26日变为 W3C 标准。W3C 将 XHTML
定义也新型的HTML版本。XHTML 将逐级替代 HTML。XHTML是通过把 HTML 和 XML
各自的独到之处加以结合形成的。XHTML 语法规则如下:

  • 属于性名和标签号必须小写

  • 属性值必须加引号

  • 性能不克简写

  • 于是 Id 属性代替 name 属性

  • XHTML 元素必须吃科学地嵌套

  • XHTML 元素必须于关

3.标签的语义化
为发挥语义而标记文档,而休是为样式,结构可以的文档可以通往浏览器传达尽可能多的语义,不论是浏览器在掌上电脑还是最新的桌面图形浏览器。结构可以的文档都能够通往用户传达可视化的语义,即使是当一味的浏览器,或是在让用户关闭了
CSS 的现代浏览器被。同时结构可以的HTML代码也推动搜索引擎索引而的网站。

  • 决不采用table布局,table是为此来表格显示的。

  • 不要到处滥用div标签,div是用来分块用之

  • 并非采用样式标签,如font, center, big, small, b,
    i,样式可以据此CSS来决定,b和i可以就此strong和em来取代。

  • 无须使换行标签<br />和空格来支配样式,请用CSS。

  • 尽心尽力不要采用内联CSS

CSS

1.基础

  • 层叠和延续

  • 优先级

  • 盒模型

  • 定位

  • 浮动

2.进阶

  • CSS Sprite:CSS
    Sprite主要用于前端性能优化的一致种技术,原理是由此以大半布置背景图片合成在相同摆设图纸上用减少HTTP请求,加快载入速度。

  • 浏览器兼容性:绝大部分情形下我们用考虑浏览器的兼容性,目前方以的浏览器版本非常多,IE6,
    IE7, IE8, IE9, IE10, Chrome, Firefox, Safari。

  • IE HasLayout和Block Format Content:IE HasLayout是一个 Internet
    Explorer for
    Windows的私有概念,它控制了一个因素如何展示和约其涵盖的情节、如何和外因素交互与建立联系、如何响应和传递应用程序事件、用户事件等。这种渲染特性可经一些
    CSS 属性被不可逆转地接触。而微 HTML
    元素则默认就拥有”layout”。目前只有IE6和IE7有其一概率。BFC是 W3C CSS
    2.1
    规范中的一个概念,它控制了元素如何对该情节开展一定,以及和外因素的涉与相互作用。这个实际与浏览器的兼容性有关,因为绝大部分底兼容性问题都是它引起的。

  • CSS Frameworks:
    CSS框架是千篇一律密密麻麻CSS文件的集合体,包含了着力的元素重置,页面排版、网格布局、表单样式、通用规则等代码块,用于简化web前端开发的办事,提高工作效率。目前广框架来:

960 Grid System
Blueprint CSS
Bluetrip
Minimum Page

或者一个比出名和奇特之框架是Twitter的Bootstrap。Bootstrap是神速支付Web应用程序的前端工具包。它是一个CSS和HTML的联谊,它以了行的浏览器技术,给您的Web开发提供了时尚之版式,表单,buttons,表格,网格系统等等。它是因Less开发的。不支持IE6,在IE7和IE8里效果呢无咬地。

  • CSS3:
    则CSS3尚没专业成正式,但是连IE9+, chrome,
    Firefox等现代浏览器还支持CSS3。CSS提供了不少原先要为此JavaScript和切图才能够搞定的职能,目前主要作用有:

圆角
多背景
@font-face
动画片及渐变
渐变色
Box阴影
RGBa-加入透明色
字阴影

  • CSS性能优化:CSS
    代码是控制页面显示样式和效益的不过直白“工具”,但是在性能调优时她们常备给
    Web 开发工程师所忽视,而其实不正经之 CSS
    会对页面渲染的频率来严重影响,尤其是于结构复杂的 Web 2.0
    页面,这种影响尤为不可磨灭。所以,写起正式之、高性能的 CSS
    代码会极大的加强应用程序的效率。

  • LESS and SASS:CSS 预处理器,用来呢 CSS
    增加一些编程的的特征,无需考虑浏览器的兼容性问题,例如你可以 CSS
    中使变量、简单的程序逻辑、函数等等在编程语言中的片基本技术,可以给你的
    CSS
    更见简洁,适应性更胜似,代码更直观等许多便宜。SASS基于Ruby开发。LESS既然可以于客户端运行,也堪凭借Node.js或者Rhino在劳务端运行。

javascript


1.基础

  • 数据类型

  • 变量

  • 表达式与运算符

  • 决定语句

  • 函数

  • 异常

  • OO

  • 事件

  • BOM

  • 闭包

2.进阶

  • DOM:DOM即文档对象模型,HTML DOM
    定义了访问与操作HTML文档的业内方法。几乎拥有的当代浏览器还能够十分好的支撑DOM了。

  • JSON:(JavaScript Object Notation)
    是同等种轻量级的数据交换格式,易于人阅读和编排,同时也易于机器解析和扭转。是时下实际数据交换的正规格式,几乎拥有语言都支持JSON,比XML强太多矣。

  • AJAX:即“Asynchronous JavaScript and XML”(异步JavaScript和-
    XML),AJAX并非缩写词,而是由Jesse James
    Gaiiett创造的名词,由Google发扬光大。用于创造更好更快和交互性更强之
    Web 应用程序的技术。

  • JavaScript
    Frameworks:极大简化我们JavaScript编程的工作量,它至关重要提供了以下几只举足轻重作用:
    DOM操作,跨浏览器兼容性,以及程序架构。当然像jQuery它自身其实并无是一个框架,它是一个仓房(lib)。目前主流的框架或库发生如下几只:

jQuery
YUI
DOJO

  • HTML5:同CSS3好像,即虽然从未成为正式,但是主流的浏览器都支持了。HTML5不是HMTL,虽然也提供了一些新标签,但是它们的主要用途还是JavaScript。HTML5要害提供以下职能:

地方音频视频播放
Canvas/SVG
地理信息
硬件加速
地面运行
本地存储
起桌面拖放文件及浏览器上传
语义化标签,Form表单

  • 前端模板:主要是为化解复杂的数量拼接问题,可以用模板语言转换化为HTML结构,可以大大简化工作量,同时代码的可维护性得到好死的增高。目前于主流前端模板来:

MustCache
JsRender

  • 前端MVC:Web应用之效能进一步强,Javascript代码也愈加多,大量之JS代码要为何种架构来组织便变成了一个归心似箭的题目,于是便有人拿传统的MVC架构移植到前者来化解这些题目。目前主流前端MVC框架主要发生以下这些:

Backbone.js
Spine
YUI
Agility.js
Ember.js
Batman.js
Dojo
AngularJS(MVVM)
KnockoutJS(MVVM)
web前端上交流群:328058344 禁止闲聊,非喜不进!

  • 模块化开发:特点是“模块化开发,按需要加载“。这中CommonJS组织定义了AMD的正统用来规范浏览器端的模块定义。RequireJS和SeaJS是实现了AMD的片只可以的框架。详见:http://www.weakweb.com/articles/341.html

  • JavaScript单元测试:QUnit

  • JavaScript设计模式

  • NodeJS:把JavaScript移植到劳动器端了,这样前端和后端就可利用同一的技术,方便统一开发。而且NodeJS是非阻塞调用的,在一定领域性能是殊强的。而且这是前端开发人员出动后台开发的好机遇,进而前后端统一出,但还要休用去念其他后台开发语言。

  • ES5:ECMAScript
    5,也便是新型的JavaScript规范,对之前的JavaScript作了诸多更上一层楼,增加了过多新的风味,比如JSONECMAScript
    5,也就是行的JavaScript规范,对前面的JavaScript作了许多改善,增加了好多新的特色,比如JSON。

Others


  • 响应式设计:伴随在各种智能装备的风靡,响应式设计本凡雅炎热。以前做网页只要面向PC机的浏览器,页面一直定位宽度就推行,比如960px,而如今经手机的访问量已超越PC机,并且配备的尺寸多种多样,未来会面再多。在这种背景下,网页支持有设施进行走访是骨干要求了,而响应式设计能够挺好之缓解这些题材。

  • Http1.1:GET,POST方式,Request/Response 头部,状态码等。

  • Web移动开:开发方式一般是native的艺术还是Web方式,作为前端开发人员来说当然是失去学习Web移动开了。PhoneGap是必学的,前端层面的框架如jQueryMobile,
    Sencha Touch, jQTouch等还是无可非议的挑三拣四。

  • 前端安全:随着前端技术之上进,安全题材早就由服务器悄然来临了每一个用户的之先头,盗取用户数据,
    制造恶意的可以自身复制的蠕虫代码,让病毒在用户中流传,使服务器当掉.
    更有甚者可能会见于用户不知觉得情况下,让用户成为攻击者,这绝不是骇人听闻。富客户端的应用越来越广阔,前端的安题材也随之大增。常见的攻击方法发生:

  • XSS,跨站脚论攻击(Cross Site
    Script)。它凭借的是黑心攻击者往Web页面里插恶意html代码,当用户浏览该页之时,嵌入的黑心html代码会于实施,从而达到恶意用户之特目的。
  • CSRF(Cross Site Request Forgery),跨站点伪造请求。顾名思义就是
    通过伪造连接要于用户不知情的情状下,让用户为友好之地位来就攻击者需要达成的一对目的。
  • cookie劫持,通过取得页面的权柄,在页面被写一个简短的顶黑心站点的请求,并带用户之cookie
    获取cookie后经cookie 就得直以被盗用户之身份登录站点。
  • 跨域处理:同源策略规定跨域之间的下论是隔离的,一个域之脚本不可知顾和操作另外一个域的绝大部分属性和法。所谓的跨域处理就是高居不用域之间的步伐互相调用,目前来那么些计来处理它。
  • 调节工具:前端的调剂工具很多,比如Firebug,Webkit核心的web
    inspector, IE的iedeveloper。HTTP相关的fiddler,
    httpwatch等,还有格式化代码的jsbeatutifier,它有助于阅读压缩处理了之JavaScript代码。IETester可以效仿所有的IE版本,是调节IE兼容性的好工具。
  • SEO:搜索引擎优化
  • A/B
    test:确定两只元素或本(A和B)哪个版本更好,你要而实验两只版。最后,选择最好的版用。
  • 可用性/可访问性:
  • 可用性指的是:产品是否爱上手,用户能否完成任务,效率如何,以及及时过程被用户的无理感受可好,是打用户的角度来拘禁产品之品质。可用性好代表产品质量高,是商店之主导竞争力。
  • 而访问性:上网用户被那些视力受损的人数,通过屏幕阅读器使用键盘命令将网页的内容念给他俩放。以语义化的HTML(结构及表现相互分离之HTML)编写的网页文件,就可以被此类用户还易导航,且网页文件中的重要性信息也更有或于这些用户找到。
  • 前者流程/部署:Grunt,Bower和Yeoman现今几是前者最流行的自动化的种构建工具
  • 正则表达式
  • 浏览器插件开发
  • 浏览器原理

联系能力
不错之前端工程师需要所有优秀的牵连能力,因为若的工作暨众人口之做事不无关系。在外情况下,前端工程师至少还设满足下列四像样客户之需要。

  • 产品经理——这些是承受策划应用程序的同众多口。他们能想像发生怎样通过应用程序来满足用户需求,以及怎样通过他们计划之模式赚到钱(往往从跟愿违)。一般的话,这些人口追求的是长的成效。

  • UI设计师——这些口承受应用程序的视觉设计以及相互模拟。他们关心的凡用户指向什么敏感、交互的一贯性以及完整的好用性。他们心爱让流畅靓丽可连无便于实现之用户界面,但考虑问题屡无周全。

  • 项目经理——这些人口承受实际地运转与保障应用程序。项目管理之关键关注点,无外乎正常运转时刻(uptime)——应用程序始终健康可用之时日、性能及了日期。项目经理追求的目标数是硬着头皮保障业务的简单化,以及无在升级翻新时引入新题材。

  • 最终用户——当然是应用程序的机要消费者。尽管我们无会见时常与最终用户打交道,但他俩之举报意见要;没人想就此的应用程序毫无价值。最终用户要求极多之虽是对个人有效的功能,以及竞争性产品所具有的职能。

打某种意义上说,优秀之前端工程师就像是同一位大使,需要随时得到在外交官的心态来应针对各个一样龙之做事。

争提高前端技术

  • Github是一个精之代码托管网站,我们好当达到创造我们个人的品类,同时为是读之好地方,我们得关心其他优秀之项目。JSFiddle是一个web开发人员的演习习场,一个得以于博上面采用的工具。我们得就此外来在线编辑一些HTML,CSS,javascript片段。你编的代码可以与其他人分享,或坐你的博客当
  • 开卷优秀之开源代码
  • 关爱技术发展趋势,了解最新的行技术,可以经过订阅知名博客,阅读技术情报获取
  • 形容博客/记笔记,可以进行文化积累。

前者修炼之路

  • 入门:打基础同时能与届品种受到去。
  • HMTL & XHTML
  • CSS基础知识
  • JavaScript基础知识
  • DOM
  • JSON
  • AJAX
  • JavaScript Frameworks
  • 深入:掌握前端核心技术,可以独立工作。
  • HTML5签,TML标签语义化
  • CSS Sprite
  • 浏览器兼容性
  • IE HasLayout和Block Format Content
  • CSS3
  • 精通JavaScript Frameworks
  • HTML5
  • 前端模板
  • 前端MVC
  • 模块化开发
  • Http1.1
  • 调节工具
  • 正则表达式
  • 响应式设计
  • web前端上交流群:328058344 禁止闲聊,非喜不进!
  • 潜出:把握总体前端项目,做尽前端项目之架构师。
  • CSS性能优化
  • LESS and SASS
  • JavaScript单元测试
  • JavaScript设计模式
  • NodeJS
  • ES5
  • Web移动开
  • 浏览器插件开发
  • 前端安全
  • 跨域处理
  • SEO
  • A/B test
  • 可用性/可访问性
  • 前端流程/部署
  • 浏览器原理
  • 进军:一代宗师。
  • 免鸣金收兵的学新的技巧
  • 相互设计力量,管理能力

前端的未来

  • 举手投足技术流路线,即深入研讨前端相关的各技术,比如浏览器原理,JavaScript本身的钻,W3C各种规范相当。前端技术提高高速,各种新技巧层出不穷,这漫长总长走下来是老大烦的。

  • 向阳交互设计方向移动,前端工程师完成一定水准后互动设计力量为会见收获那个可怜之增强,对合信息架构的握住能力啊会重复胜似。可以生好的弥补视觉设计师在交换设计达到的欠缺。这漫漫总长实在跟率先漫漫凡匪冲突之,甚至可以了解也同久总长。

  • 向阳后活动,即夺学后台开发的技术,比如JAVA/PHP等,其实绝大部分风的后台开发人员就是者状态,即前后台都开。个人认为这样的话其实已倒回老路了,毕竟前端就是自原先的后台开发那里独立出来的。

  • 往管理方向,比如项目经理,或者简直转行,比如公务员等。

相关文章