web前端常见面试题汇总

1、理论知识php

1.1、讲讲输入完网址按下回车,到看到网页这个过程当中发生了什么css

a. 域名解析html

b. 发起TCP3次握手前端

c. 创建TCP链接后发起http请求html5

d. 服务器端响应http请求,浏览器获得html代码git

e. 浏览器解析html代码,并请求html代码中的资源程序员

f. 浏览器对页面进行渲染呈现给用户github

参考《一次完整的HTTP事务是怎样一个过程》web

1.2、谈谈你对前端性能优化的理解后端

a. 请求数量:合并脚本和样式表,CSS Sprites,拆分初始化负载,划分主域

b. 请求带宽:开启GZip,精简JavaScript,移除重复脚本,图像优化,将icon作成字体

c. 缓存利用:使用CDN,使用外部JavaScriptCSS,添加Expires头,减小DNS查找,配置ETag,使AjaX可缓存

d. 页面结构:将样式表放在顶部,将脚本放在底部,尽早刷新文档的输出

e. 代码校验:避免CSS表达式,避免重定向

参考《前端工程与性能优化》

1.3、前端 MV*框架的意义

早期前端都是比较简单,基本以页面为工做单元,内容以浏览型为主,也偶尔有简单的表单操做,基本不太须要框架.

随着 AJAX 的出现,Web2.0的兴起,人们能够在页面上能够作比较复杂的事情了,而后前端框架才真正出现了。

若是是页面型产品,多数确实不太须要它,由于页面中的 JavaScript代码,处理交互的绝对远远超过处理模型的,可是若是是应用软件类产品,这就太须要了。

长期作某个行业软件的公司,通常都会沉淀下来一些业务组件,主要体如今数据模型、业务规则和业务流程,这些组件基本都存在于后端,在前端不多有相应的组织。

从协做关系上讲,不少前端开发团队每一个成员的职责不是很清晰,有了前端的 MV框架,这个情况会大有改观。

之因此感觉不到 MV*框架的重要性,是由于Model部分代码较少,View的相对多一些。若是主要在操做ViewController,那固然 jQuery 这类库比较好用了。

参考《前端 MV*框架的意义》

1.4、请简述盒模型

IE6盒子模型与W3C盒子模型。

文档中的每一个元素被描绘为矩形盒子。盒子有四个边界:外边距边界margin, 边框边界border, 内边距边界padding与内容边界content

CSS3中有个box-sizing属性能够控制盒子的计算方式,

content-boxpaddingborder不被包含在定义的widthheight以内。对象的实际宽度等于设置的width值和borderpadding之和。(W3C盒子模型)

border-boxpaddingborder被包含在定义的widthheight以内。对象的实际宽度就等于设置的width值。(IE6盒子模型)

参考《盒模型》

1.5、请你谈谈Cookie的弊端

a. 每一个特定的域名下最多生成的cookie个数有限制

b. IEOpera 会清理近期最少使用的cookieFirefox会随机清理cookie

c. cookie的最大大约为4096字节,为了兼容性,通常不能超过4095字节

d. 安全性问题。若是cookie被人拦截了,那人就能够取得全部的session信息。

1.6、浏览器本地存储

HTML5中提供了sessionStoragelocalStorage.

sessionStorage用于本地存储一个会话(session)中的数据,这些数据只有在同一个会话中的页面才能访问而且当会话结束后数据也随之销毁,是会话级别的存储。

localStorage用于持久化的本地存储,除非主动删除数据,不然数据是永远不会过时的。

 

1.7web storagecookie的区别

a. Cookie的大小是受限的

b. 每次你请求一个新的页面的时候Cookie都会被发送过去,这样无形中浪费了带宽

c. cookie还须要指定做用域,不能够跨域调用

d. Web Storage拥有setItem,getItem等方法,cookie须要前端开发者本身封装setCookiegetCookie

e. Cookie的做用是与服务器进行交互,做为HTTP规范的一部分而存在 ,而Web Storage仅仅是为了在本地“存储”数据而生

f. IE7IE6中的UserData经过简单的代码封装能够统一到全部的浏览器都支持web storage

 

 

 

1.9、线程与进程的区别

a. 一个程序至少有一个进程,一个进程至少有一个线程

b. 线程的划分尺度小于进程,使得多线程程序的并发性高

c. 进程在执行过程当中拥有独立的内存单元,而多个线程共享内存,从而极大地提升了程序的运行效率

d. 每一个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。可是线程不可以独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制

e. 多线程的意义在于一个应用程序中,有多个执行部分能够同时执行。但操做系统并无将多个线程看作多个独立的应用,来实现进程的调度和管理以及资源分配

 

1.10、请说出三种减小页面加载时间的方法

a. 尽可能减小页面中重复的HTTP请求数量

b. 服务器开启gzip压缩

c. css样式的定义放置在文件头部

d. Javascript脚本放在文件末尾

e. 压缩合并JavascriptCSS代码

f. 使用多域名负载网页内的多个文件、图片

参考《减低页面加载时间的方法》

 

1.11、你都使用哪些工具来测试代码的性能?

JSPerf, Dromaeo

 

1.12、你遇到过比较难的技术问题是?你是如何解决的?

 

1.13、常使用的库有哪些?经常使用的前端开发工具?开发过什么应用或组件?

 

1.14、列举IE与其余浏览器不同的特性?

a. IE的排版引擎是Trident (又称为MSHTML

b. Trident内核曾经几乎与W3C标准脱节(2005年)

c. Trident内核的大量 Bug等安全性问题没有获得及时解决

d. JS方面,有不少独立的方法,例如绑定事件的attachEvent、建立事件的createEventObject

e. CSS方面,也有本身独有的处理方式,例如设置透明,低版本IE中使用滤镜的方式

参考《Trident(排版引擎)》

 

1.15、什么叫优雅降级和渐进加强?

渐进加强 progressive enhancement

针对低版本浏览器进行构建页面,保证最基本的功能,而后再针对高级浏览器进行效果、交互等改进和追加功能达到更好的用户体验。

优雅降级 graceful degradation

一开始就构建完整的功能,而后再针对低版本浏览器进行兼容。

区别:

a. 优雅降级是从复杂的现状开始,并试图减小用户体验的供给

b. 渐进加强则是从一个很是基础的,可以起做用的版本开始,并不断扩充,以适应将来环境的须要

c. 降级(功能衰减)意味着往回看;而渐进加强则意味着朝前看,同时保证其根基处于安全地带

参考《优雅降级和渐进加强的区别》

 

1.16WEB应用从服务器主动推送Data到客户端有那些方式?

a. html5 websoket

b. WebSocket 经过 Flash

c. XHR长时间链接

d. XHR Multipart Streaming

e. 不可见的Iframe

f. <script>标签的长时间链接(可跨域)

 

1.17、对前端界面工程师这个职位是怎么样理解的?

a. 前端是最贴近用户的程序员,前端的能力就是能让产品从 90分进化到 100 分,甚至更好

b. 参与项目,快速高质量完成实现效果图,精确到1px

c. 与团队成员,UI设计,产品经理的沟通;

d. 作好的页面结构,页面重构和用户体验;

e. 处理hack,兼容、写出优美的代码格式;

f. 针对服务器的优化、拥抱最新前端技术。

1.18、你在如今的团队处于什么样的角色,起到了什么明显的做用?

1.19、你的优势是什么?缺点是什么?

1.20、如何管理前端团队?

1.21、最近在学什么?能谈谈你将来35年给本身的规划吗?

1.22、平时如何管理你的项目?

a. 先期团队必须肯定好全局样式(globe.css),编码模式(utf-8) 等;

b. 编写习惯必须一致(例如都是采用继承式的写法,单样式都写成一行);

c. 标注样式编写人,各模块都及时标注(标注关键样式调用的地方);

d. 页面进行标注(例如 页面 模块 开始和结束);

e. CSSHTML 分文件夹并行存放,命名都得统一(例如style.css);

f. JS 分文件夹存放 命名以该JS功能为准的英文翻译。

g. 图片采用整合的 images.png png8 格式文件使用 尽可能整合在一块儿使用方便未来的管理

 

1.23、说说最近最流行的一些东西吧?常去哪些网站?

CSDNSegmentFaultphp.netMDNcss参考手册、iconfont

underscoregithubBootstrapW3ShoolW3Cpluscaniuse

1.24FlashAjax各自的优缺点,在使用中如何取舍?

Flash

a. Flash适合处理多媒体、矢量图形、访问机器

b. CSS、处理文本上不足,不容易被搜索

Ajax

a. AjaxCSS、文本支持很好,支持搜索

b. 多媒体、矢量图形、机器访问不足

共同点:

a. 与服务器的无刷新传递消息

b. 能够检测用户离线和在线状态

c. 操做DOM

1.25、请解释一下 JavaScript 的同源策略

同源策略指的是:协议,域名,端口相同,同源策略是一种安全协议。

指一段脚本只能读取来自同一来源的窗口和文档的属性。

 

1.26AMDCMD 规范的区别?

AMD 提早执行依赖 - 尽早执行,requireJS 是它的实现

CMD 按需执行依赖 - 懒执行,seaJS 是它的实现

参考《SeaJSRequireJS最大的区别》、《与 RequireJS 的异同》

 

1.27、网站重构的理解

重构:在不改变外部行为的前提下,简化结构、添加可读性,而在网站前端保持一致的行为。

a. 使网站前端兼容于现代浏览器(针对于不合规范的CSS、如对IE6有效的)

b. 对于移动平台的优化,针对于SEO进行优化

c. 减小代码间的耦合,让代码保持弹性

d. 压缩或合并JSCSSimage等前端资源

 

1.28、浏览器的内核分别是什么?

IE浏览器的内核TridentMozillaGeckoChromeBlinkWebKit的分支)、Opera内核原为Presto,现为Blink

 

1.29、请介绍下cache-control

每一个资源均可以经过 Cache-Control HTTP 头来定义本身的缓存策略

Cache-Control 指令控制谁在什么条件下能够缓存响应以及能够缓存多久

Cache-Control 头在 HTTP/1.1 规范中定义,取代了以前用来定义响应缓存策略的头(例如 Expires)。

 

1.30、前端页面有哪三层构成,分别是什么?做用是什么?

a. 结构层:由 HTML XHTML 之类的标记语言负责建立,仅负责语义的表达。解决了页面“内容是什么”的问题。

b. 表示层:由CSS负责建立,解决了页面“如何显示内容”的问题。

c. 行为层:由脚本负责。解决了页面上“内容应该如何对事件做出反应”的问题。

 

1.31、知道的网页制做会用到的图片格式有哪些?

png-8png-24jpeggifsvg

Webp:谷歌(google)开发的一种旨在加快图片加载速度的图片格式。图片压缩体积大约只有JPEG2/3,并能节省大量的服务器带宽资源和数据空间。Facebook Ebay等知名网站已经开始测试并使用WebP格式。

Apng:全称是“Animated Portable Network Graphics, PNG的位图动画扩展,能够实现png格式的动态图片效果。04年诞生,但一直得不到各大浏览器厂商的支持,直到日前获得 iOS safari 8的支持,有望代替GIF成为下一代动态图标准。

 

1.32、一次js请求通常状况下有哪些地方会有缓存处理?

a. 浏览器端存储

b. 浏览器端文件缓存

c. HTTP缓存304

d. 服务器端文件类型缓存

e. 表现层&DOM缓存

参考《一次HTTP请求中有哪些地方能够缓存》

 

1.33、一个页面上有大量的图片(大型电商网站),加载很慢,你有哪些方法优化这些图片的加载,给用户更好的体验。

a. 图片懒加载,滚动到相应位置才加载图片。

b. 图片预加载,若是为幻灯片、相册等,将当前展现图片的前一张和后一张优先下载。

c. 使用CSSspriteSVGspriteIconfontBase64等技术,若是图片为css图片的话。

d. 若是图片过大,可使用特殊编码的图片,加载时会先加载一张压缩的特别厉害的缩略图,以提升用户体验。

 

1.34、谈谈之前端角度出发作好SEO须要考虑什么?

a. 了解搜索引擎如何抓取网页和如何索引网页

b. meta标签优化

c. 关键词分析

d. 付费给搜索引擎

e. 连接交换和连接普遍度(Link Popularity

f. 合理的标签使用

 

2、HTML

2.1<img>标签上title属性与alt属性的区别是什么?

alt属性是为了给那些不能看到你文档中图像的浏览者提供文字说明的。且长度必须少于100个英文字符或者用户必须保证替换文字尽量的短。

这包括那些使用原本就不支持图像显示或者图像显示被关闭的浏览器的用户,视觉障碍的用户和使用屏幕阅读器的用户等。

title属性为设置该属性的元素提供建议性的信息。使用title属性提供非本质的额外信息。参考《alttitle属性的区别及应用》

 

2.2、分别写出如下几个HTML标签:文字加粗、下标、居中、字体

加粗:<b><strong>

下标:<sub>

居中:<center>

字体:<font><basefont>、参考《HTML标签列表》

 

2.3、请写出至少5html5新增的标签,并说明其语义和应用场景

section:定义文档中的一个章节

nav:定义只包含导航连接的章节

header:定义页面或章节的头部。它常常包含 logo、页面标题和导航性的目录。

footer:定义页面或章节的尾部。它常常包含版权信息、法律信息连接和反馈建议用的地址。

aside:定义和页面内容关联度较低的内容——若是被删除,剩下的内容仍然很合理。

参考《HTML5 标签列表》

 

2.4、请说说你对标签语义化的理解?

a. 去掉或者丢失样式的时候可以让页面呈现出清晰的结构

b. 有利于SEO:和搜索引擎创建良好沟通,有助于爬虫抓取更多的有效信息:爬虫依赖于标签来肯定上下文和各个关键字的权重;

c. 方便其余设备解析(如屏幕阅读器、盲人阅读器、移动设备)以意义的方式来渲染网页;

d. 便于团队开发和维护,语义化更具可读性,遵循W3C标准的团队都遵循这个标准,能够减小差别化。

 

2.5Doctype做用? 严格模式与混杂模式如何区分?它们有何意义?

<!DOCTYPE> 声明位于文档中的最前面,处于 <html> 标签以前。告知浏览器以何种模式来渲染文档。

严格模式的排版和 JS 运做模式是,以该浏览器支持的最高标准运行。

在混杂模式中,页面以宽松的向后兼容的方式显示。模拟老式浏览器的行为以防止站点没法工做。

DOCTYPE不存在或格式不正确会致使文档以混杂模式呈现。

 

2.6、你知道多少种Doctype文档类型?

标签可声明三种 DTD 类型,分别表示严格版本、过渡版本以及基于框架的 HTML 文档。

HTML 4.01 规定了三种文档类型:StrictTransitional 以及 Frameset

XHTML 1.0 规定了三种 XML 文档类型:StrictTransitional 以及 Frameset

Standards (标准)模式(也就是严格呈现模式)用于呈现遵循最新标准的网页,

Quirks(包容)模式(也就是松散呈现模式或者兼容模式)用于呈现为传统浏览器而设计的网页。

 

2.7HTMLXHTML——两者有什么区别

a. XHTML 元素必须被正确地嵌套。

b. XHTML 元素必须被关闭。

c. 标签名必须用小写字母。

d. XHTML 文档必须拥有根元素。

参考《XHTML HTML 之间的差别》

 

2.8html5有哪些新特性、移除了那些元素?

a. HTML5 如今已经不是 SGML 的子集,主要是关于图像,位置,存储,多任务等功能的增长。

b. 拖拽释放(Drag and drop) API

c. 语义化更好的内容标签(header,nav,footer,aside,article,section

d. 音频、视频API(audio,video)

e. 画布(Canvas) API

f. 地理(Geolocation) API

g. 本地离线存储 localStorage 长期存储数据,浏览器关闭后数据不丢失

h. sessionStorage 的数据在页面会话结束时会被清除

i. 表单控件,calendardatetimeemailurlsearch

j. 新的技术webworker, websocket

移除的元素:

a. 纯表现的元素:basefontbigcenter, sstrikettu

b. 对可用性产生负面影响的元素:frameframesetnoframes

 

2.9iframe的优缺点?

优势:

a. 解决加载缓慢的第三方内容如图标和广告等的加载问题

b. iframe无刷新文件上传

c. iframe跨域通讯

缺点:

a. iframe会阻塞主页面的Onload事件

b. 没法被一些搜索引擎索引到

c. 页面会增长服务器的http请求

d. 会产生不少页面,不容易管理。

参考《iframe的一些记录》

 

2.10Quirks模式是什么?它和Standards模式有什么区别?

在写程序时咱们也会常常遇到这样的问题,如何保证原来的接口不变,又提供更强大的功能,尤为是新功能不兼容旧功能时。IE6之前的页面你们都不会去写DTD,因此IE6就假定 若是写了DTD,就意味着这个页面将采用对CSS支持更好的布局,而若是没有,则采用兼容以前的布局方式。这就是Quirks模式(怪癖模式,诡异模式,怪异模式)。

区别:整体会有布局、样式解析和脚本执行三个方面的区别。

a. 盒模型:在W3C标准中,若是设置一个元素的宽度和高度,指的是元素内容的宽度和高度,而在Quirks 模式下,IE的宽度和高度还包含了paddingborder

b. 设置行内元素的高宽:在Standards模式下,给<span>等行内元素设置wdithheight都不会生效,而在quirks模式下,则会生效。

c. 设置百分比的高度:在standards模式下,一个元素的高度是由其包含的内容来决定的,若是父元素没有设置百分比的高度,子元素设置一个百分比的高度是无效的用

d. 设置水平居中:使用margin:0 autostandards模式下可使元素水平居中,但在quirks模式下却会失效。

 

2.11、请阐述table的缺点

a. 太深的嵌套,好比table>tr>td>h3,会致使搜索引擎读取困难,并且,最直接的损失就是大大增长了冗余代码量。

b. 灵活性差,好比要将tr设置border等属性,是不行的,得经过td

c. 代码臃肿,当在table中套用table的时候,阅读代码会显得异常混乱

d. 混乱的colspanrowspan,用来布局时,频繁使用他们会形成整个文档顺序混乱。

e. table须要屡次计算才能肯定好其在渲染树中节点的属性,一般要花3倍于同等元素的时间。

f. 不够语义

参考《为何说table表格布局很差?》

 

2.12、简述一下srchref的区别

src用于替换当前元素;href用于在当前文档和引用资源之间确立联系。

srcsource的缩写,指向外部资源的位置,指向的内容将会嵌入到文档中当前标签所在位置

hrefHypertext Reference的缩写,指向网络资源所在位置,创建和当前元素(锚点)或当前文档(连接)之间的连接

相关文章
相关标签/搜索