前端面试HTML常考问题总结

目录

标签head, body,!Doctype的作用分别是什么?

!DOCTYPE(文档类型) 标签:

head:

body :

H5新特性

 伪类和伪元素

伪类:

伪元素:

html5语义化标签

常用语义化标签:

其它语义化标签:

语义化标签优点:

src和href的区别

src(同步加载执行)

href(异步加载执行)

script标签中defer和async的区别

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


标签head, body,!Doctype的作用分别是什么?

!DOCTYPE(文档类型) 标签:

  • 标记语言的文档类型声明,指示 web 浏览器关于页面使用哪个 HTML 版本进行编写的指令.
  • 不同的渲染模式会影响浏览器对 CSS 代码甚⾄ JavaScript 脚本的解析。它必须声明在HTML⽂档的第⼀⾏。

head:

  • 是所有头部元素的容器, 绝大多数头部标签的内容不会显示给读者
  • 该标签下所包含的部分可加入的标签有 base, link, meta, script, style和title

body :

  • 用于定义文档的主体, 包含了文档的所有内容
  • 该标签支持 html 的全局属性和事件属性.

H5新特性

  • 新增选择器 document.querySelector、document.querySelectorAll
  • 拖拽释放(Drag and drop) API
  • 媒体标签的 video(视频) 和 audio(音频)
  • 本地存储 localStorage 和 sessionStorage
  • 离线应用 manifest
  • 桌面通知 Notifications
  • 语意化标签 article、footer、header、nav、section
  • 增强表单控件 calendar、date、time、email、url、search
  • 地理位置 Geolocation
  • 多任务 webworker
  • 全双工通信协议 websocket
  • 历史管理 history
  • 跨域资源共享(CORS) Access-Control-Allow-Origin
  • 页面可见性改变事件 visibilitychange
  • 跨窗口通信 PostMessage Form Data
  • 对象 绘画 canvas

H5移除的元素:

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

(<frame> 的使用不应提倡,因为有一些缺点,比如性能问题,以及使用屏幕阅读器的用户缺少无障碍。比起 <frame>,<iframe> 更应该提倡。)

 伪类和伪元素

伪类和伪元素存在的意义都是为了操作一些通过普通的CSS选择器无法直接取到的节点。它们都相当于CSS选择器的一种扩展

伪类:

用于已有元素处于某种状态时为其添加对应的样式

常用伪类:

  • :hover 鼠标悬浮的节点
  • :active 当前选中的节点
  • :enabled 启用的元素,通常用于表单
  • :focus 当前取的焦点的元素
  • :checked 选中的元素,通常用于表单 checkbox 元素
  • :disabled 未启用的元素,通常用于表单

例如:当用户悬停在指定元素时,可以通过:hover来描述这个元素的状态,虽然它和一般css相 似,可以为已有元素添加样式,但是它只有处于DOM树无法描述的状态下才能为元素添加样式, 所以称为伪类。

伪元素

用于创建一些不在DOM树中的元素,并为其添加样式。

常用伪元素:

  • ::before 元素内容前插入新内容
  • ::after元素内容之后插入新内容
  • ::selection 选中的内容。常用于文本。
  • ::placeholder 占位符。用于设置占位符的样式。

例如,我们可以通过:before在一个元素之前添加一些文本,并为这些文本添加样式,虽然用 户可以看见 这些文本,但是它实际上并不在DOM文档中。

html5语义化标签

常用语义化标签:

<header></header>  头部

<nav></nav>  导航栏

<section></section>  区块(有语义化的div)

<main></main>  主要区域

<article></article>  主要内容

<aside></aside>  侧边栏

<footer></footer>  底部

其它语义化标签:

title !--:页面主体内容。--
hn !--:h1~h6,分级标题,<h1> 与 <title> 协调有利于搜索引擎优化。--
ul !--:无序列表。--
li !--:有序列表。--
header !--:页眉通常包括网站标志、主导航、全站链接以及搜索框。--
nav !--:标记导航,仅对文档中重要的链接群使用。--
main !--:页面主要内容,一个页面只能使用一次。如果是web应用,则包围其主要功能。--
article !--:定义外部的内容,其中的内容独立于文档的其余部分。--
section !--:定义文档中的节(section、区段)。比如章节、页眉、页脚或文档中的其他部分。-
-
aside !--:定义其所处内容之外的内容。如侧栏、文章的一组链接、广告、友情链接、相关产品列
表等。--
footer !--:页脚,只有当父级是body时,才是整个页面的页脚。--
small !--:呈现小号字体效果,指定细则,输入免责声明、注解、署名、版权。--
strong !--:和 em 标签一样,用于强调文本,但它强调的程度更强一些。--
em !--:将其中的文本表示为强调的内容,表现为斜体。--
mark !--:使用黄色突出显示部分文本。--
figure !--:规定独立的流内容(图像、图表、照片、代码等等)(默认有40px左右margin)。--
figcaption !--:定义 figure 元素的标题,应该被置于 figure 元素的第一个或最后一个子元素的
位置。--
cite !--:表示所包含的文本对某个参考文献的引用,比如书籍或者杂志的标题。--
blockquoto !--:定义块引用,块引用拥有它们自己的空间。--
q !--:短的引述(跨浏览器问题,尽量避免使用)。--
time !--:datetime属性遵循特定格式,如果忽略此属性,文本内容必须是合法的日期或者时间
格式。--
abbr !--:简称或缩写。--
dfn !--:定义术语元素,与定义必须紧挨着,可以在描述列表dl元素中使用。--
address !--:作者、相关人士或组织的联系信息(电子邮件地址、指向联系信息页的链接)。--
del !--:移除的内容。--
ins !--:添加的内容。--
code !--:标记代码。--
meter !--:定义已知范围或分数值内的标量测量。(Internet Explorer 不支持 meter 标
签)--
progress !--:定义运行中的进度(进程)。--

语义化标签优点:

  • 易于用户阅读,样式丢失的时候能让页面呈现清晰的结构
  • 有利于SEO(搜索引擎优化),搜索引擎根据标签来确定上下文和各个关键字的权重
  • 方便屏幕阅读器解析,如盲人阅读器根据语义渲染网页
  • 有利于开发和维护,语义化更具可读性,代码更好维护,与CSS3关系更和谐。

src和href的区别

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

src用于img、input、style、script、iframe;

href用于link a 标签

src(同步加载执行)

用于img、input、style、script、iframe标签

src 是 source 的缩写,指向外部资源的位置,指向的内容将会嵌入到文档中当前标签所在位置;在请求 src 资源时会将其指向的资源下载并应用到文档内,例如 js 脚本,img 图片和 frame 等元素。

<script src =”js.js”></script>

当浏览器解析到该元素时,会暂停其他资源的下载和处理,直到将该资源加载、编译、执行完毕,图片和框架等元素也如此,类似于将所指向资源嵌入当前标签内。这也是为什么将js 脚本放在底部而不是头部

href(异步加载执行)

用于link 、a 标签

href 是 Hypertext Reference 的缩写,指向网络资源所在位置,建立和当前元素或当前文档与引用资源之间的链接

<link href=”common.css” rel=”stylesheet”/>

浏览器会识别该文档为 css 文件,就会并行下载资源并且不会停止对当前文档的处理。 这也是为什么建议使用 link 方式来加载 css,而不是使用@import 方式

(link会异步加载css,而@import会在页面加载完成后才开始加载,会出现页面初始无样式也就是白屏问题。)

script标签中defer和async的区别

如果没有defer或async属性,浏览器会立即加载并执行相应的脚本(同步加载执行)。它不会等待后续加载的文档元素,读取到就会开始加载和执行,这样就阻塞了后续文档的加载


蓝色代表js脚本网络加载时间,红色代表js脚本执行时间,绿色代表html解析

defer 和 async属性都是去异步加载外部的JS脚本文件,它们都不会阻塞页面的解析,其区别如下:

  • 执行顺序:多个带async属性的标签,不能保证加载的顺序;多个带defer属性的标签,按照加载顺序执行;
  • 脚本是否并行执行:async属性,表示后续文档的加载和执行与js脚本的加载和执行是并行进行的,即异步执行;defer属性,加载后续文档的过程和js脚本的加载(此时仅加载不执行)是并行进行的(异步),js脚本需要等到文档所有元素解析完成之后才执行,DOMContentLoaded事件触发执行之前。

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

  • 行内元素有:a b span img input select strong
  • 块级元素有:div ul ol li dl dt dd h1 h2 h3 h4 h5 h6 p

空元素,即没有内容的HTML元素。空元素是在开始标签中关闭的,也就是空元素没有闭合标签:

  • 常见的有:<br><hr><img><input><link><meta>
  • 鲜见的有:<area><base><col><colgroup><command><embed><keygen><param><source><track><wbr>

空元素标签的存在有以下几个原因:

  1. 标记语言的要求:HTML和XML是标记语言,用于描述文档的结构和内容。有时候,我们需要在文档中插入一些没有实际内容的元素,如换行符、水平线、图像等。空元素标签提供了一种简洁的方式来表示这些元素。

  2. 简化解析和渲染:空元素标签不需要闭合标签,这样可以减少文档的大小,简化解析和渲染的过程。对于解析器和浏览器来说,处理空元素标签的逻辑更加简单和高效。

  3. 明确语义:空元素标签的使用可以使文档的结构更加清晰和语义化。例如,使用<br>标签表示换行,使用<img>标签表示图像,这样可以更准确地描述文档的内容和结构。

总之,空元素标签在标记语言中的存在是为了简化文档的表示和处理,并提供更明确的语义。它们在插入没有实际内容的元素时非常有用。

  • 31
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值