HTML面试题
HTML
1.HTML5 特性有哪些?语义化的做法有哪些,具体指的什么?
HTML5 新特性常用解释
- 多媒体,用于媒介回访的 video 和 audio 元素
- 图像效果,用于绘画的 canvas 元素, svg 元素等
- 离线存储,对本地离线存储能够更好的支持,比如:loaclstorage, Cookilse 等
- 设备兼容性特性,HTML5 体提供了数据与应用接入开放接口,使外部应用可以直接与浏览器内部的数据直接相连
- 连接特性,更有效的连接工作效率,是的基于页面的实时聊天,更快的网页游戏体验,更优化的在线交流得以实现,同时拥有了更有效的推送技术,Server-Sent Event 和 WebScockets 就是其中共两个特性,这两个特性能够帮助我嫩实现服务器数据,实时“推送”到客户端。以 WebScockets 为示例
// 1.建立连接
var socket = new WebSocket('ws://echo.websocket.org')
// 2.客户端和服务器之间的初始握手,这导致首次事物,并且Web应用程序准备好传输数据,打开 WebScockets 连接
socket.onopen = function (event) {}
// 3.接收服务器推送消息
socket.onmessage = function (event) {}
// 4.关闭推送
socket.close()
- 性能与集成特性,HTML5 通过 XML HttpRequest2 等技术,更好的在 Web 应用和网站多样化环境中快速工作
HTML5 新增标签(常用)
- 多媒体:
<audio>
<video>
<source>``<embed>``<track>
- 新表单元素:
<datalist>
<output>
<keygen>
- 新文档节段和纲要:
<header>
页面头部<section>
章节<aside>
边栏<article>
文档内容<footer>
页面底部
HTML 语义化具体指以下内容
- 语义特性,添加
<header></header>``<nav></nav>
等标签 - 为了在没有 css 代码时,也能呈现很好的内容结构,代码结构,以至于达到没有编程基础的非技术人员,也能看懂其代码
- 为了提高用户体验,比如:title,alt 用于解释名词和图片信息
- 利于 SEO,语义化能和搜索引擎建立良好的关系,有利于爬虫抓取更多的有效信息,爬虫依赖于标签来确定上下文和各个关键字的权重
- 便于团队开发和维护,语义化更具可读性,如果遵循 W3C 标准的团队都遵循这个标准,可以减少差异化,有利于规范化
- 方便其他设备解析(如屏幕阅读器,盲人阅读器,移动设备)以语义的方式来渲染网页
2.浏览器标准模式和怪异模式
提示
产生原因: 现代的浏览器一般都有两种渲染模式:标准模式和怪异模式,在标准模式下,浏览器按照 HTML 和 CSS 标准对文档进行解析和渲染;而在怪异模式下,浏览器则按照旧有的非标准的实现方式对文档进行解析和渲染,这样的话,对于旧有的网页,浏览器就会启动怪异模式,就能够使得旧网页正常显示;对于新的网页,则可以启动标准模式,使得新网页能够使用 HTML 和 CSS 的标准特性。
标准模式(W3C 标准) | 怪异模式(IE 盒模型) |
---|---|
给 span 等行内元素设置 width 和 height 无效 | 行内元素设置 width 和 height 生效 |
margin:0 auto 水平居中,在标准模式下没有问题 | 用 margin:0 auto 设置水平居中在怪异模式下会失效,解决办法,用 text-align 属性来解决 |
右边的这些问题,在标准模式下均不会出现问题 | 怪异模式下设置图片的 padding 会失效,怪异模式下 Table 中的字体属性不能继承上层的设置怪异模式下 white-space:pre 会失效 |
3.XHTML 与 HTML 有什么区别
- XHTML 元素必须被正确的嵌套。
- XHTML 元素必须被关闭。
- 标签名必须用小写字母。
- XHTML 文档必须拥有根元素。
4.为什么要在标签上使用 data-, 它有什么好处
- html5 规范中规定自定义属性需要添加前缀 data-,目的是提供与渲染无关的信息
- 使用 getAttribute()方法以及 setAttribute()方法操作自定义属性
- 使用 dataset 操作自定义属性。
- dataset 属性的兼容性问题,Chrome 8+ Firefox(Gecko) 6.0+ Internet Explorer 11+ Opera11.10+ Safari 6+ 以上浏览器均能很好支持,兼容信息查询
- 使用 data-属性选择器好处:绑定 DOM 强相关数据,js 传递数据
5.Meta 标签,都有一些什么特性,有什么作用
- 什么是 meta 标签:标签提供关于 HTML 文档的元数据,它不会显示在页面上,但是对于机器是可读的,可用于浏览器(如何显示内容或重新加载页面),搜索引擎(关键词),或其他 web 服务。
- meta 的作用:meta 里的数据是供机器解读的,告诉机器该如何解析这个页面,还有一个用途是可以添加服务器发送到浏览器的 HTTP 头部内容。
- 常用 meta 标签总结:Charset:它是声明文档使用的字符编码,以防乱码,而且一定要写在第一行 Viewport:主要是影响移动端页面布局的。
6.什么是 Canvas,你使用它做个什么需求
提示
什么是 Canvas : Canvas 元素是 HTML5 的一部分,允许脚本语言动态渲染位图像。Canvas 由一个可绘制地区 HTML 代码中的属性定义决定高度和宽度。JavaScript 代码可以访问该地区,通过一套完整的绘图功能类似于其他通用二维的 API,从而生成动态的图形
- 游戏:毫无疑问,游戏在 HTML5 领域具有举足轻重的地位。HTML5 在基于 Web 的图像显示方面比 Flash 更加立体、更加精巧,Ohad 认为运用 Canvas 制作的图像能够令 HTML5 游戏在流畅度和跨平台方面发挥更大的潜力。
- 图表制作:图表制作时常被人们忽略,但无论企业内部还是企业间交流合作都离不开图表。现在一些开发者使用 HTML/CSS 完成图标制作,但完全可以用 Canvas 来实现。当然,使用 SVG(可缩放矢量图形)来完成图表制作也是非常好的方法。(例如:echarts.js heightchart.js 都是基于 canvas 来绘图!)
**提示:**其实还有很多领域(例如:模拟器 / 远程计算机控制 / 字体设计 / 图像编辑器 / 其它),但是就当前来说,基于 canvas 图表制作是我们必须要掌握的能力。
7.HTML 废弃的标签有哪些
标签 | 作用 |
---|---|
<em>=<i> | 定义强调的文字 |
<ins>=<u> | 定义插入的文字 |
<del>=<s> | 定义删除的文字 |
<strong>=<b> | 定义重要性强调的文字 |
8.CSS / JS 引入的位置一般在哪里
Script 标签最好放在</body>
标签的前面,因为放在所有 body 中的标签后面就不会出现网页加载时出现空白的情况,可以持续的给用户提供视觉反馈,同时在有些情况下,会降低错误的发生;而 css 标签应该放在<head></head>
标签之间,因为如果放在</body>
标签的前面,那么当 DOM 树构建完成了,渲染树才构建,那么当渲染树构建完成,浏览器不得不再重新渲染整个页面,这样造成了资源的浪费,效率也不高,如果放在<head></head>
之间,浏览器边构建边渲染,效率要高得多
9.Meta viewport 的原理是什么
手机浏览器是把页面放在一个虚拟的“窗口”(viewport)中,通常这个虚拟的“窗口”(viewport)比屏幕宽,这样就不用把每个网页挤到很小的窗口中(这样会破坏没有针对手机浏览器优化的网页的布局),用户可以通过平移和缩放来看网页的不同部分。移动设备默认的 viewport 是 layout viewport,也就是那个比屏幕要宽的 viewport,但在进行移动设备网站的开发时,我们需要的是 ideal viewport