1 Star 0 Fork 98

孤月夜 / 前端面试秘籍

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
HTML.md 107.26 KB
一键复制 编辑 原始数据 按行查看 历史
齐丶先丶森 提交于 2022-01-27 16:05 . Update: 面试题

返回主页

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

参考答案:

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

②html 语义化让页面的内容结构化,结构更清晰,便于对浏览器、搜索引擎解析;即使在没有样式 CSS 情况下也以一种文档格式显示,并且是容易阅读的;

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

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

参与互动

2. Label 的作用是什么?是怎么用的?

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

解析:两种用法:一种是 id 绑定,一种是嵌套

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

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

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

参与互动

3.iframe 框架有哪些优缺点?

参考答案:

优点:

  • iframe 能够原封不动的把嵌入的网页展现出来。
  • 如果有多个网页引用 iframe,那么你只需要修改 iframe 的内容,就可以实现调用的每一个页面内容的更改,方便快捷。
  • 网页如果为了统一风格,头部和版本都是一样的,就可以写成一个页面,用 iframe 来嵌套,可以增加代码的可重用。
  • 如果遇到加载缓慢的第三方内容如图标和广告,这些问题可以由 iframe 来解决。

缺点:

  • 框架结构中出现各种滚动条
  • iframe 会阻塞主页面的 Onload 事件
  • 搜索引擎的检索程序无法解读这种页面,不利于 SEO
  • iframe 和主页面共享连接池,而浏览器对相同域的连接有限制,所以会影响页面的并行加载。

参与互动

4. HTML 与 XHTML 二者有什么区别,你觉得应该使用哪一个并说出理由。

参考答案:


应该使用XHTML,因为XHTML是XML重写了HTML的规范,比HTML更加严格,表现如下:

1、XHTML中所有的标记都必须有一个相应的结束标签;

2、XHTML所有标签的元素和属性的名字都必须使用小写;

3、所有的XML标记都必须合理嵌套;

4、所有的属性都必须用引号“”括起来;

5、把所有<和&特殊符号用编码表示;

6、给所有属性附一个值;

7、不要在注释内容中使用“--”;

8、图片必须使用说明文字。

参与互动

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

参考答案:将不想要自动完成的 forminput 设置为 autocomplete=off

解析:MDN

参与互动

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

参考答案:


①title用于网站信息标题,突出网站标题或关键字,一个网站可以有多个title,seo权重高于H1;H1概括的是文章主题,一个页面最好只用一个H1,seo权重低于title。

解析:

A.从网站角度而言,title则重于网站信息标题,突出网站标题或关键字用title,一篇文章,一个页面最好只

用一个H1,H1用得太多,会稀释主题;一个网站可以有多个title,最好一个单页用一个title以便突出网站页面

主题信息。

B.从文章角度而言,H1则概括的是文章主题,突出文章主题,用H1,面对的用户,要突出其视觉效果。

C.从SEO角度而言,title的权重高于H1,其适用性要比H1广。

②b为了加粗而加粗,strong为了标明重点而加粗

解析:

A.b这个标签对应 bold,即文本加粗,其目的仅仅是为了加粗显示文本,是一种样式/风格需求;

B.strong这个标签意思是加强字符的语气,表示该文本比较重要,提醒读者/终端注意。为了达到这个目的,浏览器等终端将其加粗显示;

③ 同②i为了斜体而斜体,em为了标明重点而斜体,且对于搜索引擎来说strong和em比b和i要重视的多

参与互动

7. 请描述下 SEO 中的 TDK?

参考答案:在 SEO 中,所谓的 TDK 其实就是 title、description、keywords 这三个标签,title 标题标签,description 描述标签,keywords 关键词标签

参与互动

8. 每个 HTML 文件头里都有个很重要的东西,Doctype,知道这是干什么的么?

参考答案: <! DOCTYPE> 声明位于文档中的最前面的位置,处于 <html> 标签之前。

  1. 告知浏览器文档使用哪种 HTML 或 XHTML 规范。

  2. 告诉浏览器按照何种规范解析页(如果你的页面没有 DOCTYPE 的声明,那么 compatMode 默认就是 BackCompat, 浏览器按照自己的方式解析渲染页面)

解析:

doctype 是一种标准通用标记语言的文档类型声明,目的是告诉标准通用标记语言解析器要使用什么样的文档类型定义(DTD)来解析文档。

<! DOCTYPE>声明是用来指示web浏览器关于页面使用哪个HTML版本进行编写的指令。

<! DOCTYPE>声明必须是HTML文档的第一行,位于html标签之前。

浏览器本身分为两种模式,一种是标准模式,一种是怪异模式,浏览器通过 doctype 来区分这两种模式,doctype 在 html 中的作用就是触发浏览器的标准模式,如果 html 中省略了 doctype,浏览器就会进入到 Quirks 模式的怪异状态,在这种模式下,有些样式会和标准模式存在差异,而 html 标准和 dom 标准值规定了标准模式下的行为,没有对怪异模式做出规定,因此不同浏览器在怪异模式下的处理也是不同的,所以一定要在 html 开头使用 doctype。

参与互动

9. 简述一下 src 与 href 的区别。

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

解析:

  • href
    href 标识超文本引用,用在 link 和 a 等元素上,href 是引用和页面关联,是在当前元素和引用资源之间建立联系
    若在文档中添加 href ,浏览器会识别该文档为 CSS 文件,就会并行下载资源并且不会停止对当前文档的处理。这也是为什么建议使用 link 方式加载 CSS,而不是使用 @import 方式。
  • src
    src 表示引用资源,替换当前元素,用在 img,script,iframe 上,src 是页面内容不可缺少的一部分。
    当浏览器解析到 src ,会暂停其他资源的下载和处理(图片不会暂停其他资源下载和处理),直到将该资源加载、编译、执行完毕,图片和框架等也如此,类似于将所指向资源应用到当前内容。这也是为什么建议把 js 脚本放在底部而不是头部的原因。

参考

参与互动

10. 严格模式与混杂模式

参考答案:

严格模式:以浏览器支持的最高标准运行

混杂模式:页面以宽松向下兼容的方式显示,模拟老式浏览器的行为

参与互动

11. 对于 WEB 标准以及 W3C 的理解与认识问题

参考答案:

web 标准简单来说可以分为结构、表现和行为。其中结构主要是有 HTML 标签组成。或许通俗点说,在页面 body 里面我们写入的标签都是为了页面的结构。表现即指 css 样式表,通过 css 可以是页面的结构标签更具美感。行为是指页面和用户具有一定的交互,同时页面结构或者表现发生变化,主要是有 js 组成。

web 标准一般是将该三部分独立分开,使其更具有模块化。但一般产生行为时,就会有结构或者表现的变化,也使这三者的界限并不那么清晰。

W3C 对 web 标准提出了规范化的要求,也就是在实际编程中的一些代码规范:包含如下几点

  1. 对于结构要求:(标签规范可以提高搜索引擎对页面的抓取效率,对 SEO 很有帮助)

1)标签字母要小写

2)标签要闭合

3)标签不允许随意嵌套

  1. 对于 css 和 js 来说

1)尽量使用外链 css 样式表和 js 脚本。是结构、表现和行为分为三块,符合规范。同时提高页面渲染速度,提高用户的体验。

2)样式尽量少用行间样式表,使结构与表现分离,标签的 id 和 class 等属性命名要做到见文知义,标签越少,加载越快,用户体验提高,代码维护简单,便于改版

3)不需要变动页面内容,便可提供打印版本而不需要复制内容,提高网站易用性。

参与互动

12. 列举 IE 与其他浏览器不一样的特性?

参考答案:

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

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

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

d. JS 方面,有很多独立的方法,例如绑定事件的 attachEvent、创建事件的 createEventObject 等

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

参与互动

13. 前端页面有哪三层构成,分别是什么?作用是什么?

参考答案:分成:结构层、表示层、行为层。

  1. 结构层(structural layer)

由 HTML 或 XHTML 之类的标记语言负责创建。标签,也就是那些出现在尖括号里的单词,对网页内容的语义含义做出了描述,但这些标签不包含任何关于如何显示有关内容的信息。例如,P 标签表达了这样一种语义:“这是一个文本段。”

  1. 表示层(presentation layer)

由 CSS 负责创建。 CSS 对“如何显示有关内容”的问题做出了回答。

  1. 行为层(behaviorlayer)

负责回答“内容应该如何对事件做出反应”这一问题。这是 Javascript 语言和 DOM 主宰的领域。

参与互动

14. 网页验证码是干嘛的,是为了解决什么安全问题?

参考答案:

  • 区分用户是计算机还是人的公共全自动程序。可以防止恶意破解密码、刷票、论坛灌水
  • 有效防止黑客对某一个特定注册用户用特定程序暴力破解方式进行不断的登陆尝试

参与互动

15. 为什么用多个域名存储网站资源更有效?

参考答案:

1、CDN 缓存更方便

2、突破浏览器并发限制

3、节约 cookie 带宽

4、节约主域名的连接数,优化页面响应速度

5、防止不必要的安全问题

参与互动

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

参考答案:

页面可见性: 就是对于用户来说,页面是显示还是隐藏, 所谓显示的页面,就是我们正在看的页面;隐藏的页面,就是我们没有看的页面。 因为,我们一次可以打开好多标签页面来回切换着,始终只有一个页面在我们眼前,其他页面就是隐藏的,还有一种就是.........,(把浏览器最小化,所有的页面就都不可见了)。

API 很简单,document.hidden 就返回一个布尔值,如果是 true, 表示页面可见,false 则表示,页面隐藏。 不同页面之间来回切换,触发 visibilitychange 事件。 还有一个 document.visibilityState, 表示页面所处的状态,取值:visible, hidden 等四个。

document.addEventListener("visibilitychange", function() {
    if (document.hidden) {
        document.title = "hidden";
    } else {
        document.title = "visibile";
    }
});

我们打开这个页面,然后再打开另一个页面,来回点击这两个页面,当我们看到这个页面时,标题显示 visiable , 当我们看另一个页面时,标题显示 hidden;

动画,视频,音频都可以在页面显示时打开,在页面隐藏时关闭

解析:参考

参与互动

17. Quirks(怪癖)模式是什么?它和 Standards(标准)模式有什么区别

参考答案:

1 以 ie6 为例,如果写了 DTD,就意味着这个页面将采用对 CSS 支持更好的布局,而如果没有,则采用兼容之前的布局方式。这就是 Quirks 模式(怪癖模式,诡异模式,怪异模式)。

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

设置一个元素的宽度和高度

<span> 等行内元素设置 width 和 height

用 margin:0 auto 设置水平居中

从 IE6 开始,引入了 Standards 模式,标准模式中,浏览器尝试给符合标准的文档在规范上的正确处理达到在指定浏览器中的程度。

在 IE6 之前 CSS 还不够成熟,所以 IE5 等之前的浏览器对 CSS 的支持很差, IE6 将对 CSS 提供更好的支持,然而这时的问题就来了,因为有很多页面是基于旧的布局方式写的,而如果 IE6  支持 CSS 则将令这些页面显示不正常,如何在即保证不破坏现有页面,又提供新的渲染机制呢?

在写程序时我们也会经常遇到这样的问题,如何保证原来的接口不变,又提供更强大的功能,尤其是新功能不兼容旧功能时。遇到这种问题时的一个常见做法是增加参数和分支,即当某个参数为真时,我们就使用新功能,而如果这个参数   不为真时,就使用旧功能,这样就能不破坏原有的程序,又提供新功能。IE6 也是类似这样做的,它将 DTD(文档类型定义)当成了这个“参数”,因为以前的页面大家都不会去写 DTD,所以 IE6 就假定   如果写了 DTD,就意味着这个页面将采用对 CSS 支持更好的布局,而如果没有,则采用兼容之前的布局方式。这就是 Quirks 模式(怪癖模式,诡异模式,怪异模式)。

区别:

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

盒模型:在 W3C 标准中,如果设置一个元素的宽度和高度,指的是元素内容的宽度和高度,而在 Quirks  模式下,IE 的宽度和高度还包含了 padding 和 border。

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

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

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

(还有很多,答出什么不重要,关键是看他答出的这些是不是自己经验遇到的,还是说都是看文章看的,甚至完全不知道。)

参与互动

18. div+css 的布局较 table 布局有什么优点?

参考答案:分离 方便改版 快清晰简洁 seo

  1. 改版的时候更方便 只要改 css 文件。

  2. 页面加载速度更快、结构化清晰、页面显示简洁。

  3. 表现与结构相分离。

  4. 易于优化(seo)搜索引擎更友好,排名更容易靠前。

参与互动

19. 你能描述一下渐进增强和优雅降级之间的不同吗?

参考答案:

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

(一开始保证最基本的功能,再改进和追加功能)

优雅降级  graceful degradation:一开始就构建完整的功能,然后再针对低版本浏览器进行兼容。

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

区别:优雅降级是从复杂的现状开始,并试图减少用户体验的供给,而渐进增强则是从一个非常基础的,能够起作用的版本开始,并不断扩充,以适应未来环境的需要。降级(功能衰减)意味着往回看;而渐进增强则意味着朝前看,同时保证其根基处于安全地带。

参与互动

20. 请谈一下你对网页标准和标准制定机构重要性的理解。

参考答案:降低开发难度及开发成本,减少各种 BUG、安全问题, 提高网站易用性

参与互动

21. 知道什么是微格式吗?谈谈理解。在前端构建中应该考虑微格式吗?

参考答案:微格式(Microformats)是一种让机器可读的语义化 XHTML 词汇的集合,是结构化数据的开放标准。是为特殊应用而制定的特殊格式。

优点:将智能数据添加到网页上,让网站内容在搜索引擎结果界面可以显示额外的提示。(应用范例:豆瓣,有兴趣自行 google)

参与互动

22. html 常见兼容性问题?

参考答案:

  1. 双边距 BUG float 引起的,解决办法: 使用 display解决

2.3 像素问题 使用 float 引起的,解决办法: 使用 dislpay:inline -3px

  1. 超链接 hover 点击后失效,解决办法: 使用正确的书写顺序 link visited hover active

  2. Ie z-index 问题,解决办法: 给父级添加 position:relative

  3. Png 透明 ,解决办法: 使用 js 代码

  4. Min-height 最小高度 ,解决办法: !Important 解决

7.select 在 ie6 下遮盖,解决办法: 使用 iframe 嵌套

  1. 为什么没有办法定义 1px 左右的宽度容器,解决办法: (IE6 默认的行高造成的,使用 over:hidden, zoom:0.08 line-height:1px)

  2. IE5-8 不支持 opacity,解决办法:

.opacity {
    opacity: 0.4;
    filter: alpha(opacity=60);/_ for IE5-7 _/ -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=60)";/_ for IE 8_/
}
  1. IE6 不支持 PNG 透明背景,解决办法: IE6 下使用 gif 图片

参与互动

23. 对 WEB 标准以及 W3C 的理解与认识

参考答案:标签闭合、标签小写、不乱嵌套、提高搜索机器人搜索几率、使用外 链 css 和 js 脚本、结构行为表现的分离、文件下载与页面速度更快、内容能被更多的用户所访问、内容能被更广泛的设备所访问、更少的代码和组件,容易维 护、改版方便,不需要变动页面内容、提供打印版本而不需要复制内容、提高网站易用性。

参与互动

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

参考答案:css3、js、map 加 area

一.border-radius (css3)

对于圆形,最直接的方法想到的就是 css3 的圆角属性,这个属性可以将 html 元素的形状设置为圆形,这之后你想对该圆形区域设置什么事件就设置什么事件(当然包括点击)。(这里就不做具体的 test 了)

二. 通过事件坐标来实现(js)

也就是通过 js 来进行一个区域判断,进而简介地的形成可点区域,以下给出主要的 js 测试代码:

// 获取目标元素
var box = document.getElementById("box");

// 对目标元素target的圆形区域进行一个点击事件绑定
function bindClickOnCircleArea(target, callback) {
    target.onclick = function(e) {
        e = e || window.event;

        // target中心点的坐标
        var x1 = 100;
        var y1 = 100;

        // 事件源坐标
        var x2 = e.offsetX;
        var y2 = e.offsetY;

        // 校验是否在圆形点击区,在的话就执行callback回调
        // 计算事件触发点与target中心的位置
        var len = Math.abs(Math.sqrt(Math.pow(x2 - x1, 2) + Math.pow(y2 - y1, 2)));
        // 通过半径进行校验
        if (len <= 100) {
            callback();
        } else {
            alert("死鬼,跑哪去啊,你老婆我是黄皮肤还是白皮肤都分不清了吗");
        }
    };
}

// 执行
bindClickOnCircleArea(box, function() {
    alert("老婆,你让我好找啊,呜呜呜");
});

三. 通过 map 加 area

<img src="../imgs/test.jpg" width="200" border="0" usemap="#Map" />
<map name="Map" id="Map">
    <area shape="circle" coords="100,100,100" href="http://www.baidu.com" target="_blank" />
</map>

参考

参与互动

25. 前端需要注意哪些 SEO

参考答案:

  1. 合理的 title、description、keywords:搜索对着三项的权重逐个减小,title 值强调重点即可,重要关键词出现不要超过 2 次,而且要靠前,不同页面 title 要有所不同;description 把页面内容高度概括,长度合适,不可过分堆砌关键词,不同页面 description 有所不同;keywords 列举出重要关键词即可

  2. 语义化的 HTML 代码,符合 W3C 规范:语义化代码让搜索引擎容易理解网页

  3. 重要内容 HTML 代码放在最前:搜索引擎抓取 HTML 顺序是从上到下,有的搜索引擎对抓取长度有限制,保证重要内容一定会被抓取

  4. 重要内容不要用 js 输出:爬虫不会执行 js 获取内容

  5. 少用 iframe:搜索引擎不会抓取 iframe 中的内容

  6. 非装饰性图片必须加 alt

  7. 提高网站速度:网站速度是搜索引擎排序的一个重要指标

解析:参考

参与互动

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

参考答案:

新特性:

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

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

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

  4. 画布(Canvas) API

  5. 地理(Geolocation) API

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

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

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

  9. 新的技术 webworker, websocket, Geolocation

移除的元素:

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

  2. 对可用性产生负面影响的元素: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]-->

参与互动

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

参考答案:

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

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

使用方法

只要在头部加一个 manifest 属性就 ok 了

<!DOCTYPE html>
<html manifest="cache.manifest">
...

</html>

然后 cache.manifest 文件的书写方式如下:

CACHE MANIFEST
#v0.11

CACHE:

js/app.js
css/style.css

NETWORK:
resourse/logo.png

FALLBACK:
/ /offline.html

解析:

代码说明:

离线存储的 manifest 一般由三个部分组成:

  1. CACHE:表示需要离线存储的资源列表,由于包含 manifest 文件的页面将被自动离线存储,所以不需要把页面自身也列出来。
  2. NETWORK:表示在它下面列出来的资源只有在在线的情况下才能访问,他们不会被离线存储,所以在离线情况下无法使用这些资源。不过,如果在 CACHE 和 NETWORK 中有一个相同的资源,那么这个资源还是会被离线存储,也就是说 CACHE 的优先级更高。
  3. FALLBACK:表示如果访问第一个资源失败,那么就使用第二个资源来替换他,比如上面这个文件表示的就是如果访问根目录下任何一个资源失败了,那么就去访问 offline.html。

参考

参与互动

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

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

参与互动

29. HTML 全局属性(global attribute)有哪些

参考答案:

  • accesskey: 设置快捷键,提供快速访问元素如aaa在 windows 下的 firefox 中按 alt + shift + a 可激活元素
  • class: 为元素设置类标识,多个类名用空格分开,CSS 和 javascript 可通过 class 属性获取元素
  • contenteditable: 指定元素内容是否可编辑
  • contextmenu: 自定义鼠标右键弹出菜单内容
  • data-*: 为元素增加自定义属性
  • dir: 设置元素文本方向
  • draggable: 设置元素是否可拖拽
  • dropzone: 设置元素拖放类型: copy, move, link
  • hidden: 表示一个元素是否与文档。样式上会导致元素不显示,但是不能用这个属性实现样式效果
  • id: 元素 id,文档内唯一
  • lang: 元素内容的的语言
  • spellcheck: 是否启动拼写和语法检查
  • style: 行内 css 样式
  • tabindex: 设置元素可以获得焦点,通过 tab 可以导航
  • title: 元素相关的建议信息
  • translate: 元素和子孙节点内容是否需要本地化

解析:参考

参与互动

30. Canvas 和 SVG 有什么区别?

参考答案:Canvas 和 SVG 都允许您在浏览器中创建图形,但是它们在根本上是不同的。

Canvas

描述:

通过 Javascript 来绘制 2D 图形。 是逐像素进行渲染的。 其位置发生改变,会重新进行绘制。

SVG

描述:

一种使用 XML 描述的 2D 图形的语言 SVG 基于 XML 意味着,SVG DOM 中的每个元素都是可用的,可以为某个元素附加 Javascript 事件处理器。 在 SVG 中,每个被绘制的图形均被视为对象。如果 SVG 对象的属性发生变化,那么浏览器能够自动重现图形。

比较

Canvas

  • 依赖分辨率
  • 不支持事件处理器
  • 弱的文本渲染能力
  • 能够以 .png 或 .jpg 格式保存结果图像
  • 最适合图像密集型的游戏,其中的许多对象会被频繁重绘

SVG

  • 不依赖分辨率
  • 支持事件处理器
  • 最适合带有大型渲染区域的应用程序(比如谷歌地图)
  • 复杂度高会减慢渲染速度(任何过度使用 DOM 的应用都不快)
  • 不适合游戏应用

解析:参考

参与互动

31. HTML5 为什么只需要写 <! DOCTYPE HTML>

参考答案:HTML 4.01 中的 doctype 需要对 DTD 进行引用,因为 HTML 4.01 基于 SGML。而 HTML 5 不基于 SGML,因此不需要对 DTD 进行引用,但是需要 doctype 来规范浏览器的行为。其中,SGML 是标准通用标记语言, 简单的说,就是比 HTML, XML 更老的标准,这两者都是由 SGML 发展而来的。BUT,HTML5 不是的。

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

参与互动

32.meta viewport 原理是什么?

参考答案:

meta viewport 标签的作用是让当前 viewport 的宽度等于设备的宽度,同时不允许用户进行手动缩放

viewport的原理:移动端浏览器通常都会在一个比移动端屏幕更宽的虚拟窗口中渲染页面,这个虚拟窗口就是 viewport; 目的是正常展示没有做移动端适配的网页,让他们完整的展示给用户;

解析:

Viewport :字面意思为视图窗口,在移动 web 开发中使用。表示将设备浏览器宽度虚拟成一个特定的值(或计算得出),这样利于移动 web 站点跨设备显示效果基本一致。移动版的 Safari 浏览器最新引进了 viewport 这个 meta tag,让网页开发者来控制 viewport 的大小和缩放,其他手机浏览器也基本支持。

在移动端浏览器当中,存在着两种视口,一种是可见视口(也就是我们说的设备大小),另一种是视窗视口(网页的宽度是多少)。 举个例子:如果我们的屏幕是 320 像素 * 480 像素的大小(iPhone4),假设在浏览器中,320 像素的屏幕宽度能够展示 980 像素宽度的内容。那么 320 像素的宽度就是可见视口的宽度,而能够显示的 980 像素的宽度就是视窗视口的宽度。

为了显示更多的内容,大多数的浏览器会把自己的视窗视口扩大,简易的理解,就是让原本 320 像素的屏幕宽度能够容下 980 像素甚至更宽的内容(将网页等比例缩小)。

Viewport 属性值

  • width 设置 layout viewport 的宽度,为一个正整数,或字符串"width-device"
  • initial-scale 设置页面的初始缩放值,为一个数字,可以带小数
  • minimum-scale 允许用户的最小缩放值,为一个数字,可以带小数
  • maximum-scale 允许用户的最大缩放值,为一个数字,可以带小数
  • height 设置 layout viewport 的高度,这个属性对我们并不重要,很少使用
  • user-scalable 是否允许用户进行缩放,值为"no"或"yes", no 代表不允许,yes 代表允许这些属性可以同时使用,也可以单独使用或混合使用,多个属性同时使用时用逗号隔开就行了。

参与互动

33. 对 web 标准、可用性、可访问性的理解

参考答案:

可用性(Usability):产品是否容易上手,用户能否完成任务,效率如何,以及这过程中用户的主观感受可好,是从用户的角度来看产品的质量。可用性好意味着产品质量高,是企业的核心竞争力。

可访问性(Accessibility):Web 内容对于残障用户的可阅读和可理解性

可维护性(Maintainability):一般包含两个层次,一是当系统出现问题时,快速定位并解决问题的成本,成本低则可维护性好。二是代码是否容易被人理解,是否容易修改和增强功能。

参与互动

34. HTML5 引入什么新的表单属性?

参考答案:Datalist datetime output keygen date month week time number range emailurl

参与互动

35. 新的 HTML5 文档类型和字符集是?

参考答案:

HTML5文档类型:<!doctype html>
HTML5使用的编码<meta charset=”UTF-8”>

参与互动

36. HTML5 Canvas 元素有什么用?

参考答案:Canvas 元素用于在网页上绘制图形,该元素标签强大之处在于可以直接在 HTML 上进行图形操作。

参与互动

37. HTML5 存储类型有什么区别?

参考答案:Media API、Text Track API、Application Cache API、User Interaction、Data Transfer API、Command API、Constraint Validation API、History API

参与互动

38.iframe 的作用

参考答案:iframe 是用来在网页中插入第三方页面,早期的页面使用 iframe 主要是用于导航栏这种很多页面都相同的部分,这样在切换页面的时候避免重复下载。

优点

  1. 便于修改,模拟分离,像一些信息管理系统会用到。
  2. 但现在基本不推荐使用。除非特殊需要,一般不推荐使用。

缺点

  1. iframe 的创建比一般的 DOM 元素慢了 1-2 个数量级
  2. iframe 标签会阻塞页面的的加载,如果页面的 onload 事件不能及时触发,会让用户觉得网页加载很慢,用户体验不好,在 Safari 和 Chrome 中可以通过 js 动态设置 iframe 的 src 属性来避免阻塞。
  3. iframe 对于 SEO 不友好,替换方案一般就是动态语言的 Incude 机制和 ajax 动态填充内容等。

参与互动

39. 为什么最好把 CSS 的 <link> 标签放在 <head></head> 之间?为什么最好把 JS 的 <script> 标签恰好放在 </body> 之前,有例外情况吗?

参考答案:

<link> 放在 <head>

<link> 标签放在 <head></head> 之间是规范要求的内容。此外,这种做法可以让页面逐步呈现,提高了用户体验。将样式表放在文档底部附近,会使许多浏览器(包括 Internet Explorer)不能逐步呈现页面。一些浏览器会阻止渲染,以避免在页面样式发生变化时,重新绘制页面中的元素。这种做法可以防止呈现给用户空白的页面或没有样式的内容。

<script> 标签恰好放在 </body> 之前

脚本在下载和执行期间会阻止 HTML 解析。把 <script> 标签放在底部,保证 HTML 首先完成解析,将页面尽早呈现给用户。

例外情况是当你的脚本里包含 document.write() 时。但是现在, document.write() 不推荐使用。同时,将 <script> 标签放在底部,意味着浏览器不能开始下载脚本,直到整个文档(document)被解析。也许,对此比较好的做法是, <script> 使用 defer 属性,放在 <head> 中。

参与互动

40. 什么是渐进式渲染(progressive rendering)?

参考答案:渐进式渲染是用于提高网页性能(尤其是提高用户感知的加载速度),以尽快呈现页面的技术。

在以前互联网带宽较小的时期,这种技术更为普遍。如今,移动终端的盛行,而移动网络往往不稳定,渐进式渲染在现代前端开发中仍然有用武之地。

一些举例:

  • 图片懒加载——页面上的图片不会一次性全部加载。当用户滚动页面到图片部分时,JavaScript 将加载并显示图像。
  • 确定显示内容的优先级(分层次渲染)——为了尽快将页面呈现给用户,页面只包含基本的最少量的 CSS、脚本和内容,然后可以使用延迟加载脚本或监听DOMContentLoaded/load事件加载其他资源和内容。
  • 异步加载 HTML 片段——当页面通过后台渲染时,把 HTML 拆分,通过异步请求,分块发送给浏览器。

解析:更多相关细节可以在这里找到。

参与互动

41. DOM 和 BOM 有什么区别

参考答案:

  • DOM

Document Object Model,文档对象模型

DOM 是为了操作文档出现的 API,document 是其的一个对象

DOM 和文档有关,这里的文档指的是网页,也就是 html 文档。DOM 和浏览器无关,他关注的是网页本身的内容。

  • BOM

Browser Object Model,浏览器对象模型

BOM 是为了操作浏览器出现的 API,window 是其的一个对象

window 对象既为 javascript 访问浏览器提供 API,同时在 ECMAScript 中充当 Global 对象

42.img 上 title 与 alt

参考答案:title 指图片的信息、alt 指图片不显示时显示的文字

43. 一个iframe,内嵌了一个A页面,iframe的宽高不停变化,如何让A页面的宽高实时自适应这个iframe的宽高大小。请说出至少3种方法,越难越好

参考答案:

  1. css的方案
  2. onresize
  3. 监听鼠标动作,鼠标释放后重新定宽

44. DOM Tree是如何构建的?

参考答案:

  1. HTML 解释器

HTML 解释器的工作就是将网络或者本地磁盘获取的 HTML 网页和资源从字节流解释成 DOM 树结构。

  1. JavaScript 的执行

在 HTML 解释器的工作过程中,可能会有 JavaScript 代码需要执行,它发生在将字符串解释成词语之后、创建各种节点的时候。这也是为什么全局执行的 JavaScript 代码不能访问 DOM 的原因——因为 DOM 树还没有被创建完呢。

45.100*100的 canvas 占多少内存?

参考答案:参考

46. <noscript> 标签的作用

参考答案:noscript 元素用来定义在脚本未被执行时的替代内容(文本)。

此标签可被用于可识别 <script> 标签但无法支持其中的脚本的浏览器。

47. DOCTYPE 的作用是什么?

参考答案:

相关知识点:

IE5.5 引入了文档模式的概念,而这个概念是通过使用文档类型(DOCTYPE)切换实现的。

<!DOCTYPE>声明位于 HTML 文档中的第一行,处于 <html> 标签之前。告知浏览器的解析器用什么文档标准解析这个文档。

DOCTYPE 不存在或格式不正确会导致文档以兼容模式呈现。

回答(参考1-5):

<!DOCTYPE>  声明一般位于文档的第一行,它的作用主要是告诉浏览器以什么样的模式来解析文档。一般指定了之后会以标准模式来
进行文档解析,否则就以兼容模式进行解析。在标准模式下,浏览器的解析规则都是按照最新的标准进行解析的。而在兼容模式下,浏
览器会以向后兼容的方式来模拟老式浏览器的行为,以保证一些老的网站的正确访问。

在 html5 之后不再需要指定 DTD 文档,因为 html5 以前的 html 文档都是基于 SGML 的,所以需要通过指定 DTD 来定义文
档中允许的属性以及一些规则。而 html5 不再基于 SGML 了,所以不再需要使用 DTD。

48. 标准模式与兼容模式各有什么区别?

参考答案:

标准模式的渲染方式和 JS 引擎的解析方式都是以该浏览器支持的最高标准运行。在兼容模式中,页面以宽松的向后兼容的方式显示
,模拟老式浏览器的行为以防止站点无法工作。

49. HTML5 为什么只需要写 <!DOCTYPE HTML>,而不需要引入 DTD?

参考答案:

HTML5 不基于 SGML,因此不需要对 DTD 进行引用,但是需要 DOCTYPE 来规范浏览器的行为(让浏览器按照它们应该的方式来运
行)。

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

50. SGML 、 HTML 、XML 和 XHTML 的区别?

参考答案:

SGML 是标准通用标记语言,是一种定义电子文档结构和描述其内容的国际标准语言,是所有电子文档标记语言的起源。

HTML 是超文本标记语言,主要是用于规定怎么显示网页。

XML 是可扩展标记语言是未来网页语言的发展方向,XML 和 HTML 的最大区别就在于 XML 的标签是可以自己创建的,数量无限多,
而 HTML 的标签都是固定的而且数量有限。

XHTML 也是现在基本上所有网页都在用的标记语言,他其实和 HTML 没什么本质的区别,标签都一样,用法也都一样,就是比 HTML 
更严格,比如标签必须都用小写,标签都必须有闭合标签等。

51. DTD 介绍

参考答案:

DTD( Document Type Definition 文档类型定义)是一组机器可读的规则,它们定义 XML 或 HTML 的特定版本中所有允许元
素及它们的属性和层次关系的定义。在解析网页时,浏览器将使用这些规则检查页面的有效性并且采取相应的措施。

DTD 是对 HTML 文档的声明,还会影响浏览器的渲染模式(工作模式)。

52. 行内元素定义

参考答案:

HTML4 中,元素被分成两大类: inline (内联元素)与 block(块级元素)。一个行内元素只占据它对应标签的边框所包含的空
间。

常见的行内元素有 a b span img strong sub sup button input label select textarea

53. 块级元素定义

参考答案:

块级元素占据其父元素(容器)的整个宽度,因此创建了一个“块”。

常见的块级元素有  div ul ol li dl dt dd h1 h2 h3 h4 h5 h6 p 

54. 行内元素与块级元素的区别?

参考答案:

HTML4中,元素被分成两大类:inline (内联元素)与 block (块级元素)。

(1) 格式上,默认情况下,行内元素不会以新行开始,而块级元素会新起一行。
(2) 内容上,默认情况下,行内元素只能包含文本和其他行内元素。而块级元素可以包含行内元素和其他块级元素。
(3) 行内元素与块级元素属性的不同,主要是盒模型属性上:行内元素设置 width 无效,height 无效(可以设置 line-hei
     ght),设置 margin 和 padding 的上下不会对其他元素产生影响。

55. HTML5 元素的分类

参考答案:

HTML4中,元素被分成两大类: inline(内联元素)与 block(块级元素)。但在实际的开发过程中,因为页面表现的需要,前
端工程师经常把 inline 元素的 display 值设定为 block (比如 a 标签),也经常把 block 元素的 display 值设定为
inline 之后更是出现了 inline-block 这一对外呈现 inline 对内呈现 block 的属性。因此,简单地把 HTML 元素划分为
inline 与 block 已经不再符合实际需求。

HTML5中,元素主要分为7类:Metadata Flow Sectioning Heading Phrasing Embedded Interactive

56. 空元素定义

参考答案:

标签内没有内容的 HTML 标签被称为空元素。空元素是在开始标签中关闭的。

常见的空元素有:br hr img input link meta

57. link 标签定义

参考答案:

link 标签定义文档与外部资源的关系。

link 元素是空元素,它仅包含属性。 此元素只能存在于 head 部分,不过它可出现任何次数。

link 标签中的 rel 属性定义了当前文档与被链接文档之间的关系。常见的 stylesheet 指的是定义一个外部加载的样式表。

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

参考答案:

(1)从属关系区别。 @import 是 CSS 提供的语法规则,只有导入样式表的作用;link 是 HTML 提供的标签,不仅可以加
     载 CSS 文件,还可以定义 RSS、rel 连接属性、引入网站图标等。

(2)加载顺序区别。加载页面时,link 标签引入的 CSS 被同时加载;@import 引入的 CSS 将在页面加载完毕后被加载。

(3)兼容性区别。@import 是 CSS2.1 才有的语法,故只可在 IE5+ 才能识别;link 标签作为 HTML 元素,不存在兼容
     性问题。

(4)DOM 可控性区别。可以通过 JS 操作 DOM ,插入 link 标签来改变样式;由于 DOM 方法是基于文档的,无法使用 @i
    mport 的方式插入样式。

59. async 和 defer 的作用是什么?有什么区别?(浏览器解析过程)

参考答案:

 (1)脚本没有 defer 或 async,浏览器会立即加载并执行指定的脚本,也就是说不等待后续载入的文档元素,读到就加载并执
     行。

 (2)defer 属性表示延迟执行引入的 JavaScript,即这段 JavaScript 加载时 HTML 并未停止解析,这两个过程是并行的。
     当整个 document 解析完毕后再执行脚本文件,在 DOMContentLoaded 事件触发之前完成。多个脚本按顺序执行。

 (3)async 属性表示异步执行引入的 JavaScript,与 defer 的区别在于,如果已经加载好,就会开始执行,也就是说它的执
     行仍然会阻塞文档的解析,只是它的加载过程不会阻塞。多个脚本的执行顺序无法保证。

详细资料可以参考: 《defer 和 async 的区别》

60. 什么是文档的预解析?(浏览器解析过程)

参考答案:

 Webkit 和 Firefox 都做了这个优化,当执行 JavaScript 脚本时,另一个线程解析剩下的文档,并加载后面需要通过网络加
 载的资源。这种方式可以使资源并行加载从而使整体速度更快。需要注意的是,预解析并不改变 DOM 树,它将这个工作留给主解析
 过程,自己只解析外部资源的引用,比如外部脚本、样式表及图片。

61. CSS 如何阻塞文档解析?(浏览器解析过程)

参考答案:

 理论上,既然样式表不改变 DOM 树,也就没有必要停下文档的解析等待它们,然而,存在一个问题,JavaScript 脚本执行时可
 能在文档的解析过程中请求样式信息,如果样式还没有加载和解析,脚本将得到错误的值,显然这将会导致很多问题。

 所以如果浏览器尚未完成 CSSOM 的下载和构建,而我们却想在此时运行脚本,那么浏览器将延迟 JavaScript 脚本执行和文档
 的解析,直至其完成 CSSOM 的下载和构建。也就是说,在这种情况下,浏览器会先下载和构建 CSSOM,然后再执行 JavaScript,
 最后再继续文档的解析。

62. 渲染页面时常见哪些不良现象?(浏览器渲染过程)

参考答案:

 FOUC:主要指的是样式闪烁的问题,由于浏览器渲染机制(比如firefox),在 CSS 加载之前,先呈现了 HTML,就会导致展示
       出无样式内容,然后样式突然呈现的现象。会出现这个问题的原因主要是 css 加载时间过长,或者 css 被放在了文档底
       部。

 白屏:有些浏览器渲染机制(比如chrome)要先构建 DOM 树和 CSSOM 树,构建完成后再进行渲染,如果 CSS 部分放在 HTML 
      尾部,由于 CSS 未加载完成,浏览器迟迟未渲染,从而导致白屏;也可能是把 js 文件放在头部,脚本的加载会阻塞后面
      文档内容的解析,从而页面迟迟未渲染出来,出现白屏问题。

详细资料可以参考: 《前端魔法堂:解秘 FOUC》 《白屏问题和 FOUC》

63. 如何优化关键渲染路径?(浏览器渲染过程)

参考答案:

 为尽快完成首次渲染,我们需要最大限度减小以下三种可变因素:

 (1)关键资源的数量。
 (2)关键路径长度。
 (3)关键字节的数量。

 关键资源是可能阻止网页首次渲染的资源。这些资源越少,浏览器的工作量就越小,对 CPU 以及其他资源的占用也就越少。

 同样,关键路径长度受所有关键资源与其字节大小之间依赖关系图的影响:某些资源只能在上一资源处理完毕之后才能开始下载,
 并且资源越大,下载所需的往返次数就越多。

 最后,浏览器需要下载的关键字节越少,处理内容并让其出现在屏幕上的速度就越快。要减少字节数,我们可以减少资源数(将它
 们删除或设为非关键资源),此外还要压缩和优化各项资源,确保最大限度减小传送大小。

 优化关键渲染路径的常规步骤如下:

 (1)对关键路径进行分析和特性描述:资源数、字节数、长度。
 (2)最大限度减少关键资源的数量:删除它们,延迟它们的下载,将它们标记为异步等。
 (3)优化关键字节数以缩短下载时间(往返次数)。
 (4)优化其余关键资源的加载顺序:您需要尽早下载所有关键资产,以缩短关键路径长度。

详细资料可以参考: 《优化关键渲染路径》

64. 什么是重绘和回流?(浏览器绘制过程)

参考答案:

 重绘: 当渲染树中的一些元素需要更新属性,而这些属性只是影响元素的外观、风格,而不会影响布局的操作,比如 background-color,我们将这样的操作称为重绘。
 
 回流:当渲染树中的一部分(或全部)因为元素的规模尺寸、布局、隐藏等改变而需要重新构建的操作,会影响到布局的操作,这样的操作我们称为回流。

 常见引起回流属性和方法:

 任何会改变元素几何信息(元素的位置和尺寸大小)的操作,都会触发回流。

 (1)添加或者删除可见的 DOM 元素;
 (2)元素尺寸改变——边距、填充、边框、宽度和高度
 (3)内容变化,比如用户在 input 框中输入文字
 (4)浏览器窗口尺寸改变——resize事件发生时
 (5)计算 offsetWidth 和 offsetHeight 属性
 (6)设置 style 属性的值
 (7)当你修改网页的默认字体时。

 回流必定会发生重绘,重绘不一定会引发回流。回流所需的成本比重绘高的多,改变父节点里的子节点很可能会导致父节点的一系列回流。

常见引起重绘属性和方法:

常见引起回流属性和方法

常见引起回流属性和方法:

常见引起重绘属性和方法

详细资料可以参考: 《浏览器的回流与重绘》

65. 如何减少回流?(浏览器绘制过程)

参考答案:

 (1)使用 transform 替代 top

 (2)不要把节点的属性值放在一个循环里当成循环里的变量

 (3)不要使用 table 布局,可能很小的一个小改动会造成整个 table 的重新布局

 (4)把 DOM 离线后修改。如:使用 documentFragment 对象在内存里操作 DOM

 (5)不要一条一条地修改 DOM 的样式。与其这样,还不如预先定义好 css 的 class,然后修改 DOM 的 className。

66. 为什么操作 DOM 慢?(浏览器绘制过程)

参考答案:

 一些 DOM 的操作或者属性访问可能会引起页面的回流和重绘,从而引起性能上的消耗。

67. DOMContentLoaded 事件和 Load 事件的区别?

参考答案:

 当初始的 HTML 文档被完全加载和解析完成之后,DOMContentLoaded 事件被触发,而无需等待样式表、图像和
 子框架的加载完成。

 Load 事件是当所有资源加载完成后触发的。

详细资料可以参考: 《DOMContentLoaded 事件 和 Load 事件的区别?》

68. HTML5 有哪些新特性、移除了那些元素?

参考答案:

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

 新增的有:
  
 绘画 canvas;
 用于媒介回放的 video 和 audio 元素;
 本地离线存储 localStorage 长期存储数据,浏览器关闭后数据不丢失;
 sessionStorage 的数据在浏览器关闭后自动删除;
 语意化更好的内容元素,比如 article、footer、header、nav、section;
 表单控件,calendar、date、time、email、url、search;
 新的技术 webworker, websocket;
 新的文档属性 document.visibilityState

 移除的元素有:

 纯表现的元素:basefont,big,center,font, s,strike,tt,u;
 对可用性产生负面影响的元素:frame,frameset,noframes;

69. 如何处理 HTML5 新标签的浏览器兼容问题?

参考答案:

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

 (2) 当然也可以直接使用成熟的框架,比如 html5shiv ;
      `<!--[if lt IE 9]>
      <script> src="https://cdn.jsdelivr.net/npm/html5shiv/dist/html5shiv.min.js"</script>
      <![endif]-->`

      [if lte IE 9]……[endif] 判断 IE 的版本,限定只有 IE9 以下浏览器版本需要执行的语句。

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

参考答案:

相关知识点:

 (1) 用正确的标签做正确的事情。
 (2) html 语义化让页面的内容结构化,结构更清晰,便于对浏览器、搜索引擎解析;
 (3) 即使在没有样式 CSS 情况下也以一种文档格式显示,并且是容易阅读的;
 (4) 搜索引擎的爬虫也依赖于 HTML 标记来确定上下文和各个关键字的权重,利于 SEO ;
 (5) 使阅读源代码的人对网站更容易将网站分块,便于阅读维护理解。

回答:

 我认为 html 语义化主要指的是我们应该使用合适的标签来划分网页内容的结构。html 的本质作用其实就是定义网页文档的结构,
 一个语义化的文档,能够使页面的结构更加清晰,易于理解。这样不仅有利于开发者的维护和理解,同时也能够使机器对文档内容进
 行正确的解读。比如说我们常用的 b 标签和 strong 标签,它们在样式上都是文字的加粗,但是 strong 标签拥有强调的语义。
 对于一般显示来说,可能我们看上去没有差异,但是对于机器来说,就会有很大的不同。如果用户使用的是屏幕阅读器来访问网页的
 话,使用 strong 标签就会有明显的语调上的变化,而 b 标签则没有。如果是搜索引擎的爬虫对我们网页进行分析的话,那么它会
 依赖于 html 标签来确定上下文和各个关键字的权重,一个语义化的文档对爬虫来说是友好的,是有利于爬虫对文档内容解读的,
 从而有利于我们网站的 SEO 。从 html5 我们可以看出,标准是倾向于以语义化的方式来构建网页的,比如新增了 header 、fo
 oter 这些语义标签,删除了 big 、font 这些没有语义的标签。

详细资料可以参考: 《语义化的 HTML 结构到底有什么好处?》 《如何理解 Web 语义化?》 《我的 HTML 会说话——从实用出发,谈谈 HTML 的语义化》

71. b 与 strong 的区别和 i 与 em 的区别?

参考答案:

 从页面显示效果来看,被 <b> 和 <strong> 包围的文字将会被加粗,而被 <i> 和 <em> 包围的文字将以斜体的形式呈现。

 但是 <b> <i> 是自然样式标签,分别表示无意义的加粗,无意义的斜体,表现样式为 { font-weight: bolder},仅仅表示「这
 里应该用粗体显示」或者「这里应该用斜体显示」,此两个标签在 HTML4.01 中并不被推荐使用。

 而 <em> 和 <strong> 是语义样式标签。 <em> 表示一般的强调文本,而 <strong> 表示比 <em> 语义更强的强调文本。
 
 使用阅读设备阅读网页时:<strong> 会重读,而 <b> 是展示强调内容。

详细资料可以参考: 《HTML5 中的 b/strong,i/em 有什么区别?》

72. 前端需要注意哪些 SEO ?

参考答案:

 (1)合理的 title、description、keywords:搜索对着三项的权重逐个减小,title 值强调重点即可,重要关键词出现不要超
     过2次,而且要靠前,不同页面 title 要有所不同;description 把页面内容高度概括,长度合适,不可过分堆砌关键词,不
     同页面 description 有所不同;keywords 列举出重要关键词即可。

 (2)语义化的 HTML 代码,符合 W3C 规范:语义化代码让搜索引擎容易理解网页。

 (3)重要内容 HTML 代码放在最前:搜索引擎抓取 HTML 顺序是从上到下,有的搜索引擎对抓取长度有限制,保证重要内容肯定被
     抓取。

 (4)重要内容不要用 js 输出:爬虫不会执行 js 获取内容

 (5)少用 iframe:搜索引擎不会抓取 iframe 中的内容

 (6)非装饰性图片必须加 alt

 (7)提高网站速度:网站速度是搜索引擎排序的一个重要指标

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

参考答案:

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

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

 如何使用:

 (1)创建一个和 html 同名的 manifest 文件,然后在页面头部像下面一样加入一个 manifest 的属性。

     <html lang="en" manifest="index.manifest">

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

     CACHE: 表示需要离线存储的资源列表,由于包含 manifest 文件的页面将被自动离线存储,所以不需要把页面自身也列出
            来。

     NETWORK: 表示在它下面列出来的资源只有在在线的情况下才能访问,他们不会被离线存储,所以在离线情况下无法使用这些
              资源。不过,如果在 CACHE 和 NETWORK 中有一个相同的资源,那么这个资源还是会被离线存储,也就是说 C
              ACHE 的优先级更高。

     FALLBACK: 表示如果访问第一个资源失败,那么就使用第二个资源来替换他,比如上面这个文件表示的就是如果访问根目录下
               任何一个资源失败了,那么就去访问 offline.html 。

 (3)在离线状态时,操作 window.applicationCache 进行离线缓存的操作。


 如何更新缓存:

 (1)更新 manifest 文件
 (2)通过 javascript 操作
 (3)清除浏览器缓存

 注意事项:

 (1)浏览器对缓存数据的容量限制可能不太一样(某些浏览器设置的限制是每个站点 5MB)。
 (2)如果 manifest 文件,或者内部列举的某一个文件不能正常下载,整个更新过程都将失败,浏览器继续全部使用老的缓存。
 (3)引用 manifest 的 html 必须与 manifest 文件同源,在同一个域下。
 (4)FALLBACK 中的资源必须和 manifest 文件同源。
 (5)当一个资源被缓存后,该浏览器直接请求这个绝对路径也会访问缓存中的资源。
 (6)站点中的其他页面即使没有设置 manifest 属性,请求的资源如果在缓存中也从缓存中访问。
 (7)当 manifest 文件发生改变时,资源请求本身也会触发更新。

详细的使用可以参考: 《HTML5 离线缓存-manifest 简介》 《有趣的 HTML5:离线存储》

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

参考答案:

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

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

75. 常见的浏览器端的存储技术有哪些?

参考答案:

 浏览器常见的存储技术有 cookie、localStorage 和 sessionStorage。

 还有两种存储技术用于大规模数据存储,webSQL(已被废除)和 indexDB。

 IE 支持 userData 存储数据,但是基本很少使用到,除非有很强的浏览器兼容需求。

详细的资料可以参考: 《很全很全的前端本地存储讲解》

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

参考答案:

相关资料:

 SessionStorage, LocalStorage, Cookie 这三者都可以被用来在浏览器端存储数据,而且都是字符串类型的键值对。区别
 在于前两者属于 HTML5 WebStorage,创建它们的目的便于客户端存储数据。而 cookie 是网站为了标示用户身份而储存在用户
 本地终端上的数据(通常经过加密)。cookie 数据始终在同源(协议、主机、端口相同)的 http 请求中携带(即使不需要),会
 在浏览器和服务器间来回传递。
 
 
 存储大小:
   	cookie 数据大小不能超过4 k 。
   	sessionStorage 和 localStorage 虽然也有存储大小的限制,但比 cookie 大得多,可以达到 5M 或更大。

 有期时间:
   	localStorage    存储持久数据,浏览器关闭后数据不丢失除非主动删除数据。
   	sessionStorage  数据在页面会话结束时会被清除。页面会话在浏览器打开期间一直保持,并且重新加载或恢复页面仍会
                     保持原来的页面会话。在新标签或窗口打开一个页面时会在顶级浏览上下文中初始化一个新的会话。
   	cookie          设置的 cookie 过期时间之前一直有效,即使窗口或浏览器关闭。
  
 作用域:
     sessionStorage  只在同源的同窗口(或标签页)中共享数据,也就是只在当前会话中共享。
     localStorage    在所有同源窗口中都是共享的。
     cookie          在所有同源窗口中都是共享的。

回答:

 浏览器端常用的存储技术是 cookie 、localStorage 和 sessionStorage。

 cookie 其实最开始是服务器端用于记录用户状态的一种方式,由服务器设置,在客户端存储,然后每次发起同源请求时,发送给服
 务器端。cookie 最多能存储 4 k 数据,它的生存时间由 expires 属性指定,并且 cookie 只能被同源的页面访问共享。

 sessionStorage 是 html5 提供的一种浏览器本地存储的方法,它借鉴了服务器端 session 的概念,代表的是一次会话中所保
 存的数据。它一般能够存储 5M 或者更大的数据,它在当前窗口关闭后就失效了,并且 sessionStorage 只能被同一个窗口的同源
 页面所访问共享。

 localStorage 也是 html5 提供的一种浏览器本地存储的方法,它一般也能够存储 5M 或者更大的数据。它和 sessionStorage 
 不同的是,除非手动删除它,否则它不会失效,并且 localStorage 也只能被同源页面所访问共享。

 上面几种方式都是存储少量数据的时候的存储方式,当我们需要在本地存储大量数据的时候,我们可以使用浏览器的 indexDB 这是浏
 览器提供的一种本地的数据库存储机制。它不是关系型数据库,它内部采用对象仓库的形式存储数据,它更接近 NoSQL 数据库。

详细的资料可以参考: 《请描述一下 cookies,sessionStorage 和 localStorage 的区别?》 《浏览器数据库 IndexedDB 入门教程》

77. iframe 有那些缺点?

参考答案:

 iframe 元素会创建包含另外一个文档的内联框架(即行内框架)。

 主要缺点有:

 (1) iframe 会阻塞主页面的 onload 事件。window 的 onload 事件需要在所有 iframe 加载完毕后(包含里面的元素)才
      会触发。在 Safari 和 Chrome 里,通过 JavaScript 动态设置 iframe 的 src 可以避免这种阻塞情况。
 (2) 搜索引擎的检索程序无法解读这种页面,不利于网页的 SEO 。
 (3) iframe 和主页面共享连接池,而浏览器对相同域的连接有限制,所以会影响页面的并行加载。
 (4) 浏览器的后退按钮失效。
 (5) 小型的移动设备无法完全显示框架。

详细的资料可以参考: 《使用 iframe 的优缺点》 《iframe 简单探索以及 iframe 跨域处理》

78. Label 的作用是什么?是怎么用的?

参考答案:

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

 <label for="Name">Number:</label>
 <input type=“text“ name="Name" id="Name"/>

79. HTML5 的 form 的自动完成功能是什么?

参考答案:

 autocomplete 属性规定输入字段是否应该启用自动完成功能。默认为启用,设置为 autocomplete=off 可以关闭该功能。

 自动完成允许浏览器预测对字段的输入。当用户在字段开始键入时,浏览器基于之前键入过的值,应该显示出在字段中填写的选项。

 autocomplete 属性适用于 <form>,以及下面的 <input> 类型:text, search, url, telephone, email, password, 
 datepickers, range 以及 color。

80. 如何实现浏览器内多个标签页之间的通信?

参考答案:

相关资料:

 (1)使用 WebSocket,通信的标签页连接同一个服务器,发送消息到服务器后,服务器推送消息给所有连接的客户端。

 (2)使用 SharedWorker (只在 chrome 浏览器实现了),两个页面共享同一个线程,通过向线程发送数据和接收数据来实现标
     签页之间的双向通行。

 (3)可以调用 localStorage、cookies 等本地存储方式,localStorge 另一个浏览上下文里被添加、修改或删除时,它都会触
     发一个 storage 事件,我们通过监听 storage 事件,控制它的值来进行页面信息通信;

 (4)如果我们能够获得对应标签页的引用,通过 postMessage 方法也是可以实现多个标签页通信的。

回答:

 实现多个标签页之间的通信,本质上都是通过中介者模式来实现的。因为标签页之间没有办法直接通信,因此我们可以找一个中介者,
 让标签页和中介者进行通信,然后让这个中介者来进行消息的转发。

 第一种实现的方式是使用 websocket 协议,因为 websocket 协议可以实现服务器推送,所以服务器就可以用来当做这个中介者。
 标签页通过向服务器发送数据,然后由服务器向其他标签页推送转发。

 第二种是使用 ShareWorker 的方式,shareWorker 会在页面存在的生命周期内创建一个唯一的线程,并且开启多个页面也只会使
 用同一个线程。这个时候共享线程就可以充当中介者的角色。标签页间通过共享一个线程,然后通过这个共享的线程来实现数据的交
 换。

 第三种方式是使用 localStorage 的方式,我们可以在一个标签页对 localStorage 的变化事件进行监听,然后当另一个标签页
 修改数据的时候,我们就可以通过这个监听事件来获取到数据。这个时候 localStorage 对象就是充当的中介者的角色。

 还有一种方式是使用 postMessage 方法,如果我们能够获得对应标签页的引用,我们就可以使用 postMessage 方法,进行通信。

详细的资料可以参考:

《WebSocket 教程》 《WebSocket 协议:5分钟从入门到精通》 《WebSocket 学习(一)——基于 socket.io 实现简单多人聊天室》 《使用 Web Storage API》 《JavaScript 的多线程,Worker 和 SharedWorker》 《实现多个标签页之间通信的几种方法》

81. webSocket 如何兼容低版本浏览器?

参考答案:

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

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

参考答案:

 这个新的 API 的意义在于,通过监听网页的可见性,可以预判网页的卸载,还可以用来节省资源,减缓电能的消耗。比如,一旦用户
 不看网页,下面这些网页行为都是可以暂停的。

 (1)对服务器的轮询
 (2)网页动画
 (3)正在播放的音频或视频

详细资料可以参考: 《Page Visibility API 教程》

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

参考答案:

 (1)纯 html 实现,使用 <area> 来给 <img> 图像标记热点区域的方式,<map> 标签用来定义一个客户端图像映射,<area> 
     标签用来定义图像映射中的区域,area 元素永远嵌套在 map 元素内部,我们可以将 area 区域设置为圆形,从而实现可点击
     的圆形区域。

 (2)纯 css 实现,使用 border-radius ,当 border-radius 的长度等于宽高相等的元素值的一半时,即可实现一个圆形的
     点击区域。

 (3)纯 js 实现,判断一个点在不在圆上的简单算法,通过监听文档的点击事件,获取每次点击时鼠标的位置,判断该位置是否在我
     们规定的圆形区域内。

详细资料可以参考: 《如何在页面上实现一个圆形的可点击区域?》 《HTML 标签及在实际开发中的应用》

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

参考答案: 果。

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

85. title 与 h1 的区别?

参考答案:

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

86. <img> 的 title 和 alt 有什么区别?

参考答案:

 title 通常当鼠标滑动到元素上的时候显示

 alt 是 <img> 的特有属性,是图片内容的等价描述,用于图片无法加载时显示、读屏器阅读图片。可提图片高可访问性,除了纯装
 饰图片外都必须设置有意义的值,搜索引擎会重点分析。

87. Canvas 和 SVG 有什么区别?

参考答案:

 Canvas 是一种通过 JavaScript 来绘制 2D 图形的方法。Canvas 是逐像素来进行渲染的,因此当我们对 Canvas 进行缩放时,
 会出现锯齿或者失真的情况。
 
 SVG 是一种使用 XML 描述 2D 图形的语言。SVG 基于 XML,这意味着 SVG DOM 中的每个元素都是可用的。我们可以为某个元素
 附加 JavaScript 事件监听函数。并且 SVG 保存的是图形的绘制方法,因此当 SVG 图形缩放时并不会失真。

详细资料可以参考: 《SVG 与 HTML5 的 canvas 各有什么优点,哪个更有前途?》

88. 网页验证码是干嘛的,是为了解决什么安全问题?

参考答案:

 (1)区分用户是计算机还是人的公共全自动程序。可以防止恶意破解密码、刷票、论坛灌水
 (2)有效防止黑客对某一个特定注册用户用特定程序暴力破解方式进行不断的登陆尝试

89. 渐进增强和优雅降级的定义

参考答案:

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

 优雅降级:一开始就根据高版本浏览器构建完整的功能,然后再针对低版本浏览器进行兼容。

90. attribute 和 property 的区别是什么?

参考答案:

 attribute 是 dom 元素在文档中作为 html 标签拥有的属性;
 property 就是 dom 元素在 js 中作为对象拥有的属性。
 对于 html 的标准属性来说,attribute 和 property 是同步的,是会自动更新的,
 但是对于自定义的属性来说,他们是不同步的。

91. 对 web 标准、可用性、可访问性的理解

参考答案:

 可用性(Usability):产品是否容易上手,用户能否完成任务,效率如何,以及这过程中用户的主观感受可好,是从用户的角度来看
 产品的质量。可用性好意味着产品质量高,是企业的核心竞争力

 可访问性(Accessibility):Web 内容对于残障用户的可阅读和可理解性
 
 可维护性(Maintainability):一般包含两个层次,一是当系统出现问题时,快速定位并解决问题的成本,成本低则可维护性好。
 二是代码是否容易被人理解,是否容易修改和增强功能。

92. IE 各版本和 Chrome 可以并行下载多少个资源?

参考答案:

 (1)  IE6 2 个并发
 (2)  iE7 升级之后的 6 个并发,之后版本也是 6 个
 (3)  Firefox,chrome 也是6个

93. Flash、Ajax 各自的优缺点,在使用中如何取舍?

参考答案:

 Flash:
 (1) Flash 适合处理多媒体、矢量图形、访问机器
 (2) 对 CSS、处理文本上不足,不容易被搜索

 Ajax:
 (1) Ajax 对 CSS、文本支持很好,支持搜索
 (2) 多媒体、矢量图形、机器访问不足

 共同点:
 (1) 与服务器的无刷新传递消息
 (2) 可以检测用户离线和在线状态
 (3) 操作 DOM

94. 怎么重构页面?

参考答案:

 (1) 编写 CSS
 (2) 让页面结构更合理化,提升用户体验
 (3) 实现良好的页面效果和提升性能

95. 浏览器架构

参考答案:

 * 用户界面
   * 主进程
   * 内核
       * 渲染引擎
       * JS 引擎
           * 执行栈
       * 事件触发线程
           * 消息队列
               * 微任务
               * 宏任务
       * 网络异步线程
       * 定时器线程

96. 常用的 meta 标签

参考答案:

 <meta> 元素可提供有关页面的元信息(meta-information),比如针对搜索引擎和更新频度的描述和关键词。
 <meta> 标签位于文档的头部,不包含任何内容。<meta> 标签的属性定义了与文档相关联的名称/值对。

 <!DOCTYPE html>  H5标准声明,使用 HTML5 doctype,不区分大小写
 <head lang="en"> 标准的 lang 属性写法
 <meta charset="utf-8">    声明文档使用的字符编码
 <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>   优先使用 IE 最新版本和 Chrome
 <meta name="description" content="不超过150个字符"/>       页面描述
 <meta name="keywords" content=""/>      页面关键词者
 <meta name="author" content="name, email@gmail.com"/>    网页作
 <meta name="robots" content="index,follow"/>      搜索引擎抓取
 <meta name="viewport" content="initial-scale=1, maximum-scale=3, minimum-scale=1, user-scalable=no"> 为移动设备添加 viewport
 <meta name="apple-mobile-web-app-title" content="标题"> iOS 设备 begin
 <meta name="apple-mobile-web-app-capable" content="yes"/>  添加到主屏后的标题(iOS 6 新增)
 是否启用 WebApp 全屏模式,删除苹果默认的工具栏和菜单栏
 <meta name="apple-itunes-app" content="app-id=myAppStoreID, affiliate-data=myAffiliateData, app-argument=myURL">
 添加智能 App 广告条 Smart App Banner(iOS 6+ Safari)
 <meta name="apple-mobile-web-app-status-bar-style" content="black"/>
 <meta name="format-detection" content="telphone=no, email=no"/>  设置苹果工具栏颜色
 <meta name="renderer" content="webkit">  启用360浏览器的极速模式(webkit)
 <meta http-equiv="X-UA-Compatible" content="IE=edge">     避免IE使用兼容模式
 <meta http-equiv="Cache-Control" content="no-siteapp" />    不让百度转码
 <meta name="HandheldFriendly" content="true">     针对手持设备优化,主要是针对一些老的不识别viewport的浏览器,比如黑莓
 <meta name="MobileOptimized" content="320">   微软的老式浏览器
 <meta name="screen-orientation" content="portrait">   uc强制竖屏
 <meta name="x5-orientation" content="portrait">    QQ强制竖屏
 <meta name="full-screen" content="yes">              UC强制全屏
 <meta name="x5-fullscreen" content="true">       QQ强制全屏
 <meta name="browsermode" content="application">   UC应用模式
 <meta name="x5-page-mode" content="app">    QQ应用模式
 <meta name="msapplication-tap-highlight" content="no">    windows phone 点击无高光
 设置页面不缓存
 <meta http-equiv="pragma" content="no-cache">
 <meta http-equiv="cache-control" content="no-cache">
 <meta http-equiv="expires" content="0">

详细资料可以参考: 《Meta 标签用法大全》

97. css reset 和 normalize.css 有什么区别?

参考答案:

相关知识点:

 为什么会有 CSS Reset 的存在呢?那是因为早期的浏览器支持和理解的 CSS 规范不同,导致渲染页面时效果不一致,会出现很多
 兼容性问题。

 reset 的目的,是将所有的浏览器的自带样式重置掉,这样更易于保持各浏览器渲染的一致性。

 normalize 的理念则是尽量保留浏览器的默认样式,不进行太多的重置,而尽力让这些样式保持一致并尽可能与现代标准相符合。


 1.Normalize.css 保护了有价值的默认值

 Reset 通过为几乎所有的元素施加默认样式,强行使得元素有相同的视觉效果。 相比之下,Normalize.css 保持了许多默认的浏
 览器样式。 这就意味着你不用再为所有公共的排版元素重新设置样式。 当一个元素在不同的浏览器中有不同的默认值时,Normali
 ze.css 会力求让这些样式保持一致并尽可能与现代标准相符合。


 2.Normalize.css 修复了浏览器的 bug

 它修复了常见的桌面端和移动端浏览器的 bug。这往往超出了 Reset 所能做到的范畴。关于这一点,Normalize.css 修复的问题
 包含了 HTML5 元素的显示设置、预格式化文字的 font-size 问题、在 IE9 中 SVG 的溢出、许多出现在各浏览器和操作系统中
 的与表单相关的 bug。


 3.Normalize.css 没有复杂的继承链

 使用 Reset 最让人困扰的地方莫过于在浏览器调试工具中大段大段的继承链。在 Normalize.css 中就不会有这样的问题,因为在
 我们的准则中对多选择器的使用时非常谨慎的,我们仅会有目的地对目标元素设置样式。


 4.Normalize.css 是模块化的

 这个项目已经被拆分为多个相关却又独立的部分,这使得你能够很容易也很清楚地知道哪些元素被设置了特定的值。因此这能让你自己
 选择性地移除掉某些永远不会用到部分(比如表单的一般化)。


 5.Normalize.css 拥有详细的文档

 Normalize.css 的代码基于详细而全面的跨浏览器研究与测试。这个文件中拥有详细的代码说明并在 Github Wiki 中有进一步的
 说明。这意味着你可以找到每一行代码具体完成了什么工作、为什么要写这句代码、浏览器之间的差异,并且你可以更容易地进行自己
 的测试。

回答:

 css reset 是最早的一种解决浏览器间样式不兼容问题的方案,它的基本思想是将浏览器的所有样式都重置掉,从而达到所有浏览器
 样式保持一致的效果。但是使用这种方法,可能会带来一些性能上的问题,并且对于一些元素的不必要的样式的重置,其实反而会造成
 画蛇添足的效果。

 后面出现一种更好的解决浏览器间样式不兼容的方法,就是 normalize.css ,它的思想是尽量的保留浏览器自带的样式,通过在原
 有的样式的基础上进行调整,来保持各个浏览器间的样式表现一致。相对与 css reset,normalize.css 的方法保留了有价值的默
 认值,并且修复了一些浏览器的 bug,而且使用 normalize.css 不会造成元素复杂的继承链。

详细资料可以参考: 《关于CSS Reset 那些事(一)之 历史演变与 Normalize.css》 《Normalize.css 和 Reset CSS 有什么本质区别没?》

98. 用于预格式化文本的标签是?

参考答案:

 预格式化就是保留文字在源码中的格式 最后显示出来样式与源码中的样式一致 所见即所得。

 <pre> 定义预格式文本,保持文本原有的格式

99. DHTML 是什么?

参考答案:

 DHTML 将 HTML、JavaScript、DOM 以及 CSS 组合在一起,用于创造动态性更强的网页。通过 JavaScript 和 HTML DOM,能
 够动态地改变 HTML 元素的样式。

 DHTML 实现了网页从 Web 服务器下载后无需再经过服务的处理,而在浏览器中直接动态地更新网页的内容、排版样式和动画的功
 能。例如,当鼠标指针移到文章段落中时,段落能够变成蓝色,或者当鼠标指针移到一个超级链接上时,会自动生成一个下拉式子链
 接目录等。

 包括:
 (1)动态内容(Dynamic Content):动态地更新网页内容,可“动态”地插入、修改或删除网页的元件,如文字、图像、标记等。

 (2)动态排版样式(Dynamic Style Sheets):W3C 的 CSS 样式表提供了设定 HTML 标记的字体大小、字形、样式、粗细、
     文字颜色、行高度、加底线或加中间横线、缩排、与边缘距离、靠左右或置中、背景图片或颜色等排版功能,而“动态排版样
     式”即可以“动态”地改变排版样式。

100. head 标签中必不少的是?

参考答案:

 <head> 标签用于定义文档的头部,它是所有头部元素的容器。<head> 中的元素可以引用脚本、指示浏览器在哪里找到样式表、提供
 元信息等等。

 文档的头部描述了文档的各种属性和信息,包括文档的标题、在 Web 中的位置以及和其他文档的关系等。绝大多数文档头部包含的数
 据都不会真正作为内容显示给读者。

 下面这些标签可用在 head 部分:<base>, <link>, <meta>, <script>, <style>, 以及 <title>。

 <title> 定义文档的标题,它是 head 部分中唯一必需的元素。

101. HTML5 新增的表单元素有?

参考答案:

 datalist 规定输入域的选项列表,通过 option 创建! 
 
 keygen 提供一种验证用户的可靠方法,密钥对生成器,私钥存于客户端,公钥发到服务器,用于之后验证客户端证书!
 
 output 元素用于不同类型的输出!

102. 在 HTML5 中,哪个方法用于获得用户的当前位置?

参考答案:

 getCurrentPosition()

103. 文档的不同注释方式?

参考答案:

 HTML 的注释方法 <!--注释内容--> 
 
 CSS 的��释方法 /*注释内容*/ 
 
 JavaScript 的注释方法 /* 多行注释方式 */ //单行注释方式

104. disabled 和 readonly 的区别?

参考答案:

 disabled 指当 input 元素加载时禁用此元素。input 内容不会随着表单提交。
  
 readonly 规定输入字段为只读。input 内容会随着表单提交。

 无论设置 readonly 还是 disabled,通过 js 脚本都能更改 input 的 value

105. 主流浏览器内核私有属性 css 前缀?

参考答案:

 mozilla 内核 (firefox,flock 等)    -moz
 webkit  内核 (safari,chrome 等)   -webkit
 opera   内核 (opera 浏览器)        -o
 trident 内核 (ie 浏览器)           -ms

106. 前端性能优化?

参考答案:

 前端性能优化主要是为了提高页面的加载速度,优化用户的访问体验。我认为可以从这些方面来进行优化。

 第一个方面是页面的内容方面

 (1)通过文件合并、css 雪碧图、使用 base64 等方式来减少 HTTP 请求数,避免过多的请求造成等待的情况。

 (2)通过 DNS 缓存等机制来减少 DNS 的查询次数。

 (3)通过设置缓存策略,对常用不变的资源进行缓存。

 (4)使用延迟加载的方式,来减少页面首屏加载时需要请求的资源。延迟加载的资源当用户需要访问时,再去请求加载。

 (5)通过用户行为,对某些资源使用预加载的方式,来提高用户需要访问资源时的响应速度。

 第二个方面是服务器方面

 (1)使用 CDN 服务,来提高用户对于资源请求时的响应速度。

 (2)服务器端启用 Gzip、Deflate 等方式对于传输的资源进行压缩,减小文件的体积。

 (3)尽可能减小 cookie 的大小,并且通过将静态资源分配到其他域名下,来避免对静态资源请求时携带不必要的 cookie

 第三个方面是 CSS 和 JavaScript 方面

 (1)把样式表放在页面的 head 标签中,减少页面的首次渲染的时间。

 (2)避免使用 @import 标签。

 (3)尽量把 js 脚本放在页面底部或者使用 defer 或 async 属性,避免脚本的加载和执行阻塞页面的渲染。

 (4)通过对 JavaScript 和 CSS 的文件进行压缩,来减小文件的体积。

详细的资料可以参考: 《前端性能优化之雅虎35条军规》 《你真的了解 gzip 吗?》 《前端性能优化之 gzip》

107. Chrome 中的 Waterfall ?

参考答案:

详细资料可以参考: 《前端性能之 Chrome 的 Waterfall》 《教你读懂网络请求的瀑布图》 《前端妹子跟我抱怨她们的页面加载很慢的时候,如何在她面前优雅地装逼?》

108. 扫描二维码登录网页是什么原理,前后两个事件是如何联系的?

参考答案:

 核心过程应该是:浏览器获得一个临时 id,通过长连接等待客户端扫描带有此 id 的二维码后,从长连接中获得客户端上报给 serv
 er的帐号信息进行展示。并在客户端点击确认后,获得服务器授信的令牌,进行随后的信息交互过程。在超时、网络断开、其他设备
 上登录后,此前获得的令牌或丢失、或失效,对授权过程形成有效的安全防护。

 我的理解

 二维码登录网页的基本原理是,用户进入登录网页后,服务器生成一个 uid 来标识一个用户。对应的二维码对应了一个对应 uid 
 的链接,任何能够识别二维码的应用都可以获得这个链接,但是它们没有办法和对应登录的服务器响应。比如微信的二维码登录,只
 有用微信识这个二维码才有效。当微信客户端打开这个链接时,对应的登录服务器就获得了用户的相关信息。这个时候登录网页根据
 先前的长连接获取到服务器传过来的用户信息进行显示。然后提前预加载一些登录后可能用到的信息。当客户端点击确认授权登陆后,
 服务器生成一个权限令牌给网页,网页之后使用这个令牌进行信息的交互过程。由于整个授权的过程都是在手机端进行的,因此能够
 很好的防止 PC 上泛滥的病毒。并且在超时、网络断开、其他设备上登录后,此前获得的令牌或丢失、或失效,对授权过程能够形成
 有效的安全防护。

详细资料可以参考: 《微信扫描二维码登录网页》

109. Html 规范中为什么要求引用资源不加协议头http或者https

参考答案:

 如果用户当前访问的页面是通过 HTTPS 协议来浏览的,那么网页中的资源也只能通过 HTTPS 协议来引用,否则浏览器会出现
 警告信息,不同浏览器警告信息展现形式不同。

 为了解决这个问题,我们可以省略 URL 的协议声明,省略后浏览器照样可以正常引用相应的资源,这项解决方案称为
  protocol-relative URL,暂且可译作协议相对 URL。

 如果使用协议相对 URL,无论是使用 HTTPS,还是 HTTP 访问页面,浏览器都会以相同的协议请求页面中的资源,避免弹出类似
 的警告信息,同时还可以节省5字节的数据量。

详细资料可以参考: 《协议相对 URL》 《Why you need protocol-relative URLs now

110. Data URI scheme 是什么 ?

参考答案:

Data URI scheme 是在 RFC2397 中定义的,目的是将一些小的数据,直接嵌入到网页中,从而不用再从外部文件载入。减少对 HTTP 的请求次数。达到优化网页的效果。

base64 后面那一串字符,其实是一张图片,将这些字符串复制粘贴到浏览器的中打开,就能看到图片了

假设你有的图像:A.jpg ,把它在网页上显示出来的标准方法是:

<img src="http://sjolzy.cn/images/A.jpg"/>

这种取得数据的方法称为 http URI scheme 。

<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAQAAAADCAIAAAA7ljmRAAAAGElEQVQIW2P4DwcMDAxAfBvMAhEQMYgcACEHG8ELxtbPAAAAAElFTkSuQmCC" />

这种取得数据的方法称为 Data URI scheme 。

111. Data URI scheme 的语法

参考答案:

在上面的 Data URI scheme 中:

data 表示取得数据的协定名称;

image/png 是数据类型名称;

base64 是数据的编码方法,逗号后面就是这个image/png文件base64编码后的数据。

目前,Data URI scheme支持的类型有:

data: 文本数据
data: text/plain, ------- 文本数据
data: text/html, -------- HTML代码
data: text/html;base64, -------- base64编码的HTML代码
data: text/css, ---------- CSS代码
data: text/css;base64, ---------- base64编码的CSS代码
data: text/javascript, ------------ Javascript代码
data: text/javascript;base64, --------- base64编码的Javascript代码
data: image/gif;base64, ---------------- base64编码的gif图片数据
data: image/png;base64, -------------- base64编码的png图片数据
data: image/jpeg;base64, ------------- base64编码的jpeg图片数据
data: image/x-icon;base64, ---------- base64编码的icon图片数据

① 在 HTML 中使用 data URL (不建议这样使用)

<img src="data:image/png;base64,image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAQAAAADCAIAAAA7ljmRAAAAGElEQVQIW2P4DwcMDAxAfBvMAhEQMYgcACEHG8ELxtbPAAAAAElFTkSuQmCC"/>

② 在 CSS 中使用 data URL

body { 
   background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAQAAAADCAIAAAA7ljmRAAAAGElEQVQIW2P4DwcMDAxAfBvMAhEQMYgcACEHG8ELxtbPAAAAAElFTkSuQmCC")
};

③ 在 script 中使用 data URL

   _captchaImage() {
		captchaImage().then(res => {  //请求接口
			if (res.code == 200) {
				this.codeUrl = 'data:image/gif;base64,' + res.img; // 拼接请求回来的数据
				this.formModel.uuid = res.uuid;
		   }
	   });
	}

112. Data URI scheme 的优缺点

参考答案:

优点:

减少HTTP请求数,没有了TCP连接消耗和同一域名下浏览器的并发数限制。对于小文件会降低带宽。虽然编码后数据量会增加,但是却减少了http头,当http头的数据量大于文件编码的增量,那么就会降低带宽。 对于HTTPS站点,HTTPS和HTTP混用会有安全提示,而HTTPS相对于HTTP来讲开销要大更多,所以Data URI在这方面的优势更明显。可以把整个多媒体页面保存为一个文件。

缺点:

1.无法被重复利用,同一个文档多次被应用到同一内容中,数据被大量增加,消耗了下载时间。
2.无法被独自缓存,其包含文档重新加载时,它也要重新加载。
3.耗时,客户端需要重新解码和显示,增加消耗。
4.不支持数据压缩,base64编码会增加1/3大小,而urlencode后数据量会增加更多
5.不安全,不利于安全软件的过滤,同时也存在一定的安全隐患。

解析:参考

113. 你有使用过MediaRecorder吗?说说它的运用场景有哪些?

参考答案:录屏

114.H5的哪些特性需要https支持呢?

参考答案:service workers

service worker 是什么?

一个服务器与浏览器之间的中间人角色,如果网站中注册了service worker那么它可以拦截当前网站所有的请求,并且可以让开发者自己控制管理缓存的内容以及版本

115.你知道短链接的生成原理吗?

参考答案:

目的将长度较长的链接压缩成较短的链接,并通过跳转的方式,将用户请求由短链接重定向到长链接上去

1.二种方式生成短链

    hash-可能会重复
    发号器发号压缩 URL

2.短链跳转方式

    301 - 用户第一次访问某个短链接后,如果服务器返回301状态码,则这个用户在后续多次访问统一短链接,浏览器会直接请求跳转地址,而不是短链接地址,这样一来服务器端就无法收到用户的请求
    缺点:有缓存情况下直接跳转原地址,无法记录准确的访问

    302-浏览器不缓存短链接请求,那么用户每次访问短链接,都会先去短链接服务端取回长链接地址,然后在跳转。
    缺点:服务器压力大

116.HTML5拖拽事件的顺序是什么?

参考答案:

ondragstart :源对象开始被拖动
ondrag:源对象被拖动过程中
ondragend:源对象被拖动结束

ondragenter:源对象拖动着进入目标对象
ondragover:源对象拖动着悬停在目标对方上方
ondragleave:源对象拖动着离开了目标对象
ondrop:源对象拖动着目标对象上方释放

117. 为什么我们要使用web workers?

参考答案:

因为js是单线程,如果存在大数据运算的时候会影响用户使用体验,出现卡顿的情况。
使用web workers 可以开启一个线程,在运算的同时,不影响用户体验。
web workers的几个使用场景可以参考下:

    当大图片canvas转base64的时候非常耗时,就可以使用wokers
    端对端加密的时候,要大量计算,可以使用wokers
    拼写检查,检索的所有工作可以让wokers来完成,不会阻塞UI
    indexdb ,在网络不稳定情况下,使用indexdb api的时候,可以交给wokers,这样不会阻塞主线UI

118. 使用svg画一个微信的logo

参考答案:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
  <!--绿色大椭圆下的小尾巴-->
  <polygon points="70,92 85,97 65,107"
  style="fill:#84d845;"/>
  <!--绿色大椭圆-->
  <ellipse cx="100" cy="60" rx="50" ry="42" style="fill:#84d845;" />
  <!--灰色小椭圆下的小尾巴-->
  <polygon points="150,115 160,110 165,120"
  style="fill:#f1f2f4;"/>
  <!--灰色小椭圆-->
  <ellipse cx="135" cy="85" rx="40" ry="32" style="fill:#f1f2f4;" />
  <!--两只大眼睛-->
  <ellipse cx="82" cy="45" rx="5" ry="5" style="fill:#136f1a;" />
  <ellipse cx="115" cy="45" rx="5" ry="5" style="fill:#136f1a;" />
  <!--两只小眼睛-->
  <ellipse cx="120" cy="75" rx="4" ry="4" style="fill:#797d7e;" />
  <ellipse cx="145" cy="75" rx="4" ry="4" style="fill:#797d7e;" />
</svg>

119. 如何在不同的端口间共享cookie?

参考答案:根据同源策略,cookie是区分端口的,但是浏览器实现来说,“cookie区分域,而不区分端口,也就是说,同一个ip下的多个端口下的cookie是共享的。

参考答案:

参考答案:

参考答案:

1
https://gitee.com/lonely-moon-night/web-interview.git
git@gitee.com:lonely-moon-night/web-interview.git
lonely-moon-night
web-interview
前端面试秘籍
master

搜索帮助