前端面试题2016--HTML

本文由我收集总结了一些前端面试题,初学者阅后也要用心钻研其中的原理,重要知识须要系统学习、透彻学习,造成本身的知识链。万不可投机取巧,临时抱佛脚只求面试侥幸混过关是错误的!也是不可能的!不可能的!不可能的!javascript

 

前端仍是一个年轻的行业,新的行业标准, 框架, 库都不断在更新和新增。正如赫门在2015深JS大会上的《前端服务化之路》主题演讲中说的一句话:“每18至24个月,前端都会难一倍”,这些变化使前端的能力更加丰富、创造的应用也会更加完美。因此关注各类前端技术,跟上快速变化的节奏,也是身为一个前端程序员必备的技能之一。css

 

 

但愿前端er达到既能使用也会表达,对理论知识有本身的理解。可根据下面的知识点一个一个去进阶学习,造成本身的职业技能链。html

 

 

 

 

面试有几点需注意:(来源github:@wintercn)前端

 

一、面试题目: 根据你的等级和职位的变化,入门级到专家级,广度和深度都会有所增长。html5

 

二、题目类型: 理论知识、算法、项目细节、技术视野、开放性题、工做案例。java

 

三、细节追问: 能够确保问到你开始不懂或面试官开始不懂为止,这样能够大大延展题目的区分度和深度,知道你的实际能力。由于这种知识关联是长时期的学习,临时抱佛脚绝对是记不住的。git

 

四、回答问题再棒,面试官(多是你面试职位的直接领导),会考虑我要不要这我的作个人同事?因此态度很重要、除了能作事,还要会作人。(感受更像是相亲( ))程序员

 

五、资深的前端开发能把absolute和relative弄混,这样的人不要也罢,由于团队须要的是:你这我的具备能够依靠的才能(靠谱)。github

 

前端开发知识点:web

 

HTML&CSS:

对Web标准的理解、浏览器内核差别、兼容性、hack

CSS基本功:布局、盒子模型、选择器优先级

HTML五、CSS三、Flexbox

 

JavaScript:

数据类型、运算、对象、Function、继承、闭包、做用域、原型链、事件、RegExp、JSON、Ajax、

DOM、BOM、内存泄漏、跨域、异步装载、模板引擎、前端MVC、路由、模块化、Canvas、ECMAScript 六、Nodejs

 

其余:

移动端、响应式、自动化构建、HTTP、离线存储、

WEB安全、优化、重构

团队协做、可维护、易用性、SEO、UED、架构

职业生涯、快速学习能力

做为一名前端工程师,不管工做年头长短都应该掌握的知识点:

 

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

 

二、DOM操做 —— 如何添加、移除、移动、复制、建立和查找节点等。

 

三、事件 —— 如何使用事件,以及IE和标准DOM事件模型之间存在的差异。

 

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

 

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

 

六、盒模型 —— 外边距、内边距和边框之间的关系,及IE8如下版本的浏览器中的盒模型

 

七、块级元素与行内元素 —— 怎么用CSS控制它们、以及如何合理的使用它们

 

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

 

九、HTML与XHTML —— 两者有什么区别,你以为应该使用哪个并说出理由。

 

十、JSON —— 做用、用途、设计结构。

备注:

 

根据本身须要选择性阅读,面试题是对理论知识的总结,让本身学会应该如何表达。

 

资料答案不够正确和全面,欢迎Star和提交issues。

 

格式不断修改更新中。

HTML面试题集合

 

Doctype做用?标准模式与兼容模式各有什么区别?

 

(1)<!DOCTYPE>声明位于位于HTML文档中的第一行,处于 <html> 标签以前。告知浏览器的解析器用什么文档标准解析这个文档。DOCTYPE不存在或格式不正确会致使文档以兼容模式呈现。

 

(2)标准模式的排版 和JS运做模式都是以该浏览器支持的最高标准运行。在兼容模式中,页面以宽松的向后兼容的方式显示,模拟老式浏览器的行为以防止站点没法工做。

HTML5 为何只须要写 <!DOCTYPE HTML>?

 

HTML5 不基于 SGML,所以不须要对DTD进行引用,可是须要doctype来规范浏览器的行为(让浏览器按照它们应该的方式来运行);

 

而HTML4.01基于SGML,因此须要对DTD进行引用,才能告知浏览器文档所使用的文档类型。

行内元素有哪些?块级元素有哪些? 空(void)元素有那些?

 

首先:CSS规范规定,每一个元素都有display属性,肯定该元素的类型,每一个元素都有默认的display值,如div的display默认值为“block”,则为“块级”元素;span默认display属性值为“inline”,是“行内”元素。

(1)行内元素有:a b span img input select strong(强调的语气)

(2)块级元素有:div ul ol li dl dt dd h1 h2 h3 h4…p

(3)常见的空元素:

    <br> <hr> <img> <input> <link> <meta>

    不为人知的是:

    <area> <base> <col> <command> <embed> <keygen> <param> <source> <track> <wbr>

页面导入样式时,使用link和@import有什么区别?

 

(1)link属于XHTML标签,除了加载CSS外,还能用于定义RSS, 定义rel链接属性等做用;而@import是CSS提供的,只能用于加载CSS;

 

(2)页面被加载的时,link会同时被加载,而@import引用的CSS会等到页面被加载完再加载;

 

(3)import是CSS2.1 提出的,只在IE5以上才能被识别,而link是XHTML标签,无兼容问题;

介绍一下你对浏览器内核的理解?

 

主要分红两部分:渲染引擎(layout engineer或Rendering Engine)和JS引擎。

渲染引擎:负责取得网页的内容(HTML、XML、图像等等)、整理讯息(例如加入CSS等),以及计算网页的显示方式,而后会输出至显示器或打印机。浏览器的内核的不一样对于网页的语法解释会有不一样,因此渲染的效果也不相同。全部网页浏览器、电子邮件客户端以及其它须要编辑、显示网络内容的应用程序都须要内核。

 

JS引擎则:解析和执行javascript来实现网页的动态效果。

 

最开始渲染引擎和JS引擎并无区分的很明确,后来JS引擎愈来愈独立,内核就倾向于只指渲染引擎。

常见的浏览器内核有哪些?

 

Trident内核:IE,MaxThon,TT,The World,360,搜狗浏览器等。[又称MSHTML]

Gecko内核:Netscape6及以上版本,FF,MozillaSuite/SeaMonkey等

Presto内核:Opera7及以上。                  [Opera内核原为:Presto,现为:Blink;]

Webkit内核:Safari,Chrome等。                   [ Chrome的:Blink(WebKit的分支)]

 

html5有哪些新特性、移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分 HTML 和 HTML5?

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

  绘画 canvas;

  用于媒介回放的 video 和 audio 元素;

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

  sessionStorage 的数据在浏览器关闭后自动删除;

  语意化更好的内容元素,好比 article、footer、header、nav、section;

  表单控件,calendar、date、time、email、url、search;

  新的技术webworker, websocket, Geolocation;

 

  移除的元素:

  纯表现的元素:basefont,big,center,font, s,strike,tt,u;

  对可用性产生负面影响的元素:frame,frameset,noframes;

 

* 支持HTML5新标签:

  IE8/IE7/IE6支持经过document.createElement方法产生的标签,

  能够利用这一特性让这些浏览器支持HTML5新标签,

  浏览器支持新标签后,还须要添加标签默认的样式。

  固然也能够直接使用成熟的框架、好比html5shim;

     <!--[if lt IE 9]>

        <script> src="http://html5shim.googlecode.com/svn/trunk/html5.js"</script>

     <![endif]-->

 

* 如何区分HTML5:DOCTYPE声明\新增的结构元素\功能元素

简述一下你对HTML语义化的理解?

 

用正确的标签作正确的事情。

html语义化让页面的内容结构化,结构更清晰,便于对浏览器、搜索引擎解析;

即便在没有样式CSS状况下也以一种文档格式显示,而且是容易阅读的;

搜索引擎的爬虫也依赖于HTML标记来肯定上下文和各个关键字的权重,利于SEO;

使阅读源代码的人对网站更容易将网站分块,便于阅读维护理解。

HTML5的离线储存怎么使用,工做原理能不能解释一下?

 

在用户没有与因特网链接时,能够正常访问站点或应用,在用户与因特网链接时,更新用户机器上的缓存文件。

原理:HTML5的离线存储是基于一个新建的.appcache文件的缓存机制(不是存储技术),经过这个文件上的解析清单离线存储资源,这些资源就会像cookie同样被存储了下来。以后当网络在处于离线状态下时,浏览器会经过被离线存储的数据进行页面展现。

 

 

如何使用:

一、页面头部像下面同样加入一个manifest的属性;

二、在cache.manifest文件的编写离线存储的资源;

    CACHE MANIFEST

    #v0.11

    CACHE:

    js/app.js

    css/style.css

    NETWORK:

    resourse/logo.png

    FALLBACK:

    / /offline.html

三、在离线状态时,操做window.applicationCache进行需求实现。

浏览器是怎么对HTML5的离线储存资源进行管理和加载的呢?

 

在线的状况下,浏览器发现html头部有manifest属性,它会请求manifest文件,若是是第一次访问app,那么浏览器就会根据manifest文件的内容下载相应的资源而且进行离线存储。若是已经访问过app而且资源已经离线存储了,那么浏览器就会使用离线的资源加载页面,而后浏览器会对比新的manifest文件与旧的manifest文件,若是文件没有发生改变,就不作任何操做,若是文件改变了,那么就会从新下载文件中的资源并进行离线存储。

离线的状况下,浏览器就直接使用离线存储的资源。

请描述一下 cookies,sessionStorage 和 localStorage 的区别?

 

cookie是网站为了标示用户身份而储存在用户本地终端(Client Side)上的数据(一般通过加密)。

cookie数据始终在同源的http请求中携带(即便不须要),记会在浏览器和服务器间来回传递。

sessionStorage和localStorage不会自动把数据发给服务器,仅在本地保存。

 

存储大小:

 cookie数据大小不能超过4k。

 sessionStorage和localStorage 虽然也有存储大小的限制,但比cookie大得多,能够达到5M或更大。

 

有期时间:

localStorage    存储持久数据,浏览器关闭后数据不丢失除非主动删除数据;

sessionStorage  数据在当前浏览器窗口关闭后自动删除。

cookie          设置的cookie过时时间以前一直有效,即便窗口或浏览器关闭

iframe有那些缺点?

 

*iframe会阻塞主页面的Onload事件;

*搜索引擎的检索程序没法解读这种页面,不利于SEO;

 

*iframe和主页面共享链接池,而浏览器对相同域的链接有限制,因此会影响页面的并行加载。

 

使用iframe以前须要考虑这两个缺点。若是须要使用iframe,最好是经过javascript

动态给iframe添加src属性值,这样能够绕开以上两个问题。

Label的做用是什么?是怎么用的?

 

label标签来定义表单控制间的关系,当用户选择该标签时,浏览器会自动将焦点转到和标签相关的表单控件上。

 

<label for="Name">Number:</label>

<input type=“text“name="Name" id="Name"/>

 

<label>Date:<input type="text" name="B"/></label>

HTML5的form如何关闭自动完成功能?

 

给不想要提示的 form 或某个 input 设置为 autocomplete=off。

如何实现浏览器内多个标签页之间的通讯? (阿里)

 

WebSocket、SharedWorker;

也能够调用localstorge、cookies等本地存储方式;

 

localstorge另外一个浏览上下文里被添加、修改或删除时,它都会触发一个事件,

咱们经过事件,控制它的值来进行页面信息通讯;

注意quirks:Safari 在无痕模式下设置localstorge值时会抛出 QuotaExceededError 的异常;

webSocket如何兼容低浏览器?(阿里)

 

Adobe Flash Socket 、

ActiveX HTMLFile (IE) 、

基于 multipart 编码发送 XHR 、

基于长轮询的 XHR

页面可见性(Page Visibility API) 能够有哪些用途?

 

经过 visibilityState 的值检测页面当前是否可见,以及打开网页的时间等

在页面被切换到其余后台进程的时候,自动暂停音乐或视频的播放;

如何在页面上实现一个圆形的可点击区域?

 

一、map+area或者svg

二、border-radius

三、纯js实现 须要求一个点在不在圆上简单算法、获取鼠标坐标等等

实现不使用 border 画出1px高的线,在不一样浏览器的标准模式与怪异模式下都能保持一致的效果。

 

<div style="height:1px;overflow:hidden;background:red"></div>

网页验证码是干吗的,是为了解决什么安全问题。

 

区分用户是计算机仍是人的公共全自动程序。能够防止恶意破解密码、刷票、论坛灌水;

有效防止黑客对某一个特定注册用户用特定程序暴力破解方式进行不断的登录尝试。

title与h1的区别、b与strong的区别、i与em的区别?

 

title属性没有明确意义只表示是个标题,H1则表示层次明确的标题,对页面信息的抓取也有很大的影响;

 

strong是标明重点内容,有语气增强的含义,使用阅读设备阅读网络时:<strong>会重读,而<B>是展现强调内容。

 

i内容展现为斜体,em表示强调的文本;

 

Physical Style Elements -- 天然样式标签

b, i, u, s, pre

Semantic Style Elements -- 语义样式标签

strong, em, ins, del, code

应该准确使用语义样式标签, 但不能滥用, 若是不能肯定时首选使用天然样式标签。

相关文章
相关标签/搜索
本站公众号
   欢迎关注本站公众号,获取更多信息