前端面试题及其总结

13,301 阅读9分钟

HTML部分

1、Doctype作用?标准模式与兼容模式有什么区别?

  • 声明位于HTML文档的第一行,处于标签之前。用来告知浏览器的解析器用什么文档标准解析这个文档。DOCTYPE不存在或格式不正确会导致文档以兼容模式呈现
  • 标准模式:排版和js运作方式都是以该浏览器支持的最高标准运行。
  • 兼容模式:页面以宽松的向后兼容的方式显示,模拟老式浏览器的行为以防止站点无法运行。
  • 例子:1、width不同 在严格模式中,width是内容宽度(content),但是在兼容模式中,width是(元素的实际宽度),(怪异盒模型是margin之外是width的范围)

2、html5为什么只需要写<!DOCTYPE>

HTML5不基于SGML,因此不需要对DTD进行引用,但是需要doctype来规范浏览器的行为

所以,html5只有一种:<!DOCTYPE> 但是html4.01有三种,分别是strict(不包含展示性和弃用元素,不允许框架集)、transitional(包含展示性和弃用元素,不允许框架集)、frameset(允许框架集)

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

常见的行内元素有:a,b,span,img(我曾以为是block),input,strong,select

常见的块级元素有:div、ul(无序)、ol(有序)、li、p等

常见的空元素:<br><hr><link><script>

空元素定义:html元素的内容就是其两个标签之间的content,所以,标签之间没有内容的就是空元素

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

写法上:

<link rel="stylesheet" href="路径" />

<style type="text/css">
    @import '路径'
</style>

本质上:link属于XHTML标签,除了加载css之外,还能定义RSS,定义rel连接属性等作用。而@import是css提供的,只能用于加载css

解析上:link是跟着页面加载同时加载的,但是@import会等到页面加载完再加载

兼容上:@import IE5以上才能识别,无限制

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

主要分为两部分:

  • 渲染引擎
  • JS引擎

渲染引擎:取得网页的内容(html、xml、图片)、构造cssom树、计算网页的显示方式,比如各元素宽高,然后输出至显示器或打印机。

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

6、常见的浏览器内核有哪些(背记)?

  • Trident内核:IE,MaxThon,TT,The World,360,搜狗浏览器等。[又称MSHTML]
  • Gecko内核:Netscape6及以上版本,FF,MozillaSuite/SeaMonkey等
  • Presto内核:Opera7及以上。 [Opera内核原为:Presto,现为:Blink;]
  • Webkit内核:Safari,Chrome等。 [ Chrome的:Blink(WebKit的分支)]

*Blink是Chrome使用的,webkit的简化版本,但是效率等都较之前有了提升

详细文章:浏览器内核的解析和对比

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

实现上:h5不再是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;

处理兼容性: IE8/IE7/IE6支持通过document.createElement方法产生的标签,可以利用这一特性让这些浏览器支持HTML5新标签,浏览器支持新标签后,还需要添加标签默认的样式。

也可以使用html5shim,可以让IE9或更低版本能支持html5

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

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

8、对html语义化的理解(了解)

  • 用正确的标签做正确的事情。
  • html语义化让页面的内容结构化,结构更清晰,便于对浏览器、搜索引擎解析;
  • html语义化让页面的内容结构化,结构更清晰,便于对浏览器、搜索引擎解析;
  • 搜索引擎的爬虫也依赖于HTML标记来确定上下文和各个关键字的权重,利于SEO;
  • 使阅读源代码的人对网站更容易将网站分块,便于阅读维护理解。

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

在用户没有与因特网连接时,可以正常访问站点或应用,在用户与因特网连接时,更新用户机器上的缓存文件。 原理:HTML5的离线存储是基于一个新建的.appcache文件的缓存机制(不是存储技术),通过这个文件上的解析清单离线存储资源,这些资源就会像cookie一样被存储了下来。之后当网络在处于离线状态下时,浏览器会通过被离线存储的数据进行页面展示。

如何使用:

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

2、在cache.manifest文件的编写离线存储的资源; CACHE MANIFEST #v0.11 CACHE: js/app.js css/style.css NETWORK: resourse/logo.png FALLBACK: / /offline.html

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

10、浏览器是怎么对HTML5的离线储存资源进行管理和加载的呢?(这个比上面重要)

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

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

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

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

  • cookie数据始终在同源的http请求中携带(即使不需要),记会在浏览器和服务器间来回传递。
  • sessionStorage和localStorage不会自动把数据发给服务器,仅在本地保存。

存储大小:

  • cookie数据大小不能超过4k。
  • sessionStorage和localStorage 虽然也有存储大小的限制,但比cookie大得多,可以达到5M或更大。

有期时间:

  • localStorage 存储持久数据,浏览器关闭后数据不丢失除非主动删除数据;
  • sessionStorage 数据在当前浏览器窗口关闭后自动删除。
  • cookie 设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭

12、iframe有那些缺点?

  • iframe会阻塞主页面的Onload事件;
  • 搜索引擎的检索程序无法解读这种页面,不利于SEO;
  • iframe和主页面共享连接池,而浏览器对相同域的连接有限制,所以会影响页面的并行加载。
  • 使用iframe之前需要考虑这两个缺点。如果需要使用iframe,最好是通过javascript
  • 动态给iframe添加src属性值,这样可以绕开以上两个问题。

13、Label的作用是什么?是怎么用的?

用来关联某个标签,可以是表单标签,也可以是button,这样就可以直接点击label的范围来触发绑定标签的事件

用法:

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

自动完成:当你给输入框输入内容时,浏览器会从之前同名输入框的历史记录中查找出类似的内容并列在输入框下面。

给form或者该input设置autocomplete=off。

经过实验,提交之后,历史记录才会存储,当然,必须是name相同的input才会共享历史记录

15、如何实现浏览器内多个标签页之前的通信(阿里)?

WebSocket、SharedWorder(需要实现试试)

也可以调用localstorage、cookies等本地存储方式

16、webSocket如何兼容低浏览器?(阿里)(暂时没有实现)

Adobe Flash Socket 、ActiveX HTMLFile (IE) 、基于 multipart 编码发送 XHR 、基于长轮询的 XHR

17、页面可见性(Page Visibility API) 可以有哪些用途?

页面可见性:该网页是否处于可见状态。比如网页最小化,或是一个非前置的网页卡,那么visibilityState 的值就是hidden,如果是可见状态,则是visible。

用途:

  • 通过 visibilityState 的值检测页面当前是否可见,以及打开网页的时间等;
  • 在页面被切换到其他后台进程的时候,自动暂停音乐或视频的播放;

详细可见:Page Visibility(页面可见性) API介绍、微拓展

18、如何在页面上实现一个圆形的可点击区域?(只有第二个会,其余需要实现)

1、map+area或者svg

2、border-radius

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

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

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

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

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

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

简单的归总,就是为了分清楚操作者是人还是恶意程序

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

这个问题涉及到语义化的问题

title属性没有明确意义只表示是个标题,H1则表示层次明确的标题,主要影响的页面爬虫与SEO

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

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

Physical Style Elements -- 自然样式标签: b, i, u, s, pre

Semantic Style Elements -- 语义样式标签:strong, em, ins, del, code

如果不能确定时首选使用自然样式标签。

(。。。未完待续)