1. 行内元素有哪些?块级元素有哪些?
在 HTML 中,元素可以分为两类:行内元素(Inline Elements)和块级元素(Block-level Elements)。它们在默认情况下在页面中的表现和排列方式有所不同。
行内元素(Inline Elements):
<span>
:用于设置文本的样式或标记文本的一部分。<a>
:用于创建超链接。<img>
:用于嵌入图像。<strong>
:表示文本的强调语气,通常呈现为加粗样式。<em>
:表示文本的强调语气,通常呈现为斜体样式。<br>
:用于换行。<input>
:用于创建输入字段,如文本输入框、复选框等。
块级元素(Block-level Elements):
<div>
:用于组合其他元素,通常用于布局和分组。<p>
:用于段落文本。<h1> - <h6>
:用于标题,其中<h1>
是最高级别的标题。<ul>
:无序列表。<ol>
:有序列表。<li>
:列表项,用于<ul>
或<ol>
中。<table>
:用于创建表格。<form>
:用于创建表单。<header>
:表示页面或区域的页眉。<footer>
:表示页面或区域的页脚。<nav>
:表示导航链接。<article>
:表示独立的内容块,如新闻文章。<section>
:表示文档的一节或一个区域。
需要注意的是,行内元素一般只占据其内容的宽度,不会独占一行;而块级元素通常会独占一行,并且默认情况下会占据其父元素的整个宽度。但是,这些元素的表现方式可以通过 CSS 样式进行修改和调整。
2. 空(void)元素有哪些?块、行、行内块如何转换?
空(void)元素是指在 HTML 中没有内容的元素,它们没有开始标签和结束标签,通常用于插入非文本内容,如图像、换行等。HTML 中的空元素包括:
<br>
:换行元素,用于在文本中插入换行。<hr>
:水平线元素,用于插入水平分隔线。<img>
:图像元素,用于嵌入图像。<input>
:输入元素,用于创建输入字段,如文本输入框、复选框等。<meta>
:元数据元素,用于设置文档的元数据信息,例如字符编码和视口设置。
关于块、行、行内块元素之间的转换,这涉及到 CSS 中的 display
属性,可以通过设置不同的 display
属性值来改变元素在页面中的表现方式。
- 块级元素转换为行内元素:
- 设置
display: inline
或display: inline-block
可以将块级元素转换为行内元素或行内块元素。 - 例如,将
<div>
元素转换为行内元素:div { display: inline; }
- 行内元素转换为块级元素:
- 设置
display: block
可以将行内元素转换为块级元素。 - 例如,将
<span>
元素转换为块级元素:span { display: block; }
- 行内元素转换为行内块元素:
- 设置
display: inline-block
可以将行内元素转换为行内块元素。 - 例如,将
<span>
元素转换为行内块元素:span { display: inline-block; }
通过修改 display
属性,可以灵活地控制元素在页面中的排列方式,使其在布局上更加符合需求。但需要注意,某些元素天生是块级元素或行内元素,并且不能通过 display
属性改变它们的基本性质。比如,<div>
元素是块级元素,不能直接通过设置 display: inline
让它变为行内元素。
3. title与h2的区别、b与strong的区别、i与em的区别?
<title>
与<h1>
的区别:
<title>
元素:<title>
是 HTML 文档的头部元素,用于设置页面的标题。它在浏览器的标签栏或窗口标题栏中显示页面的标题,也是搜索引擎显示的标题。<h1>
元素:<h1>
是 HTML 中的标题级别一元素,表示页面或内容的主标题。它通常用于标记页面中最重要的标题,并且具有较大的字号和加粗样式。
<b>
与<strong>
的区别:
<b>
元素:<b>
是 HTML 中的文本粗体元素,用于设置文本的粗体样式。它仅仅表示文本的视觉效果为加粗,并没有强调的语义含义。<strong>
元素:<strong>
也是用于设置文本的粗体样式,但它具有强调的语义含义,表示文本的重要性或强调的内容。搜索引擎和屏幕阅读器等工具会将<strong>
元素中的文本视为更重要的内容。
<i>
与<em>
的区别:
<i>
元素:<i>
是 HTML 中的斜体文本元素,用于设置文本的斜体样式。它通常只表示文本的视觉效果为斜体,并没有强调的语义含义。<em>
元素:<em>
是用于表示强调文本的元素,通常呈现为斜体样式。它在语义上表示文本的强调,可以用于强调关键词、重要信息等。与<strong>
不同,<em>
表示的强调程度较轻。
需要注意的是,虽然 <b>
和 <i>
可以设置文本样式,但它们不具有语义含义。在语义化的 HTML 语义中,推荐使用 <strong>
和 <em>
来表示文本的强调和重要性。例如,如果想将某个关键词加粗并强调其重要性,应该使用 <em>
元素而不是 <b>
元素。
4. 程序设计尺寸单位分别有哪些
当进行程序设计时,不同尺寸单位用于控制元素的大小、间距、边框等,以实现合适的界面布局和适配不同设备的显示效果。以下是每个尺寸单位的详细介绍和使用说明:
- 像素(Pixel,px):
- 介绍:像素是屏幕上的最小显示单位,它是固定的物理尺寸。在 CSS 中,1px 表示一个设备上的一个物理像素点。
- 使用说明:像素是最常用的尺寸单位,可以直接指定固定的像素值。但是需要注意,使用固定像素值可能导致在不同设备上的显示效果不同,不利于响应式设计。
- 百分比(Percentage,%):
- 介绍:百分比单位相对于父元素的大小进行计算,可以用于调整元素相对于其容器的尺寸。
- 使用说明:使用百分比可以实现响应式设计,让元素相对于其容器进行自适应调整。例如,设置宽度为
50%
可以使元素占据其容器宽度的一半。
- 视口宽度单位(Viewport Width,vw):
- 介绍:视口宽度单位相对于视口宽度的百分比,视口是可见内容的区域,不包括浏览器的工具栏和滚动条。
- 使用说明:视口宽度单位可以用于实现响应式设计,让元素相对于视口宽度进行自适应调整。例如,设置宽度为
50vw
可以使元素宽度为视口宽度的一半。
- 视口高度单位(Viewport Height,vh):
- 介绍:视口高度单位相对于视口高度的百分比。
- 使用说明:视口高度单位可以用于实现响应式设计,让元素相对于视口高度进行自适应调整。例如,设置高度为
50vh
可以使元素高度为视口高度的一半。
- 根元素字体大小单位(Root Em,rem):
- 介绍:根元素字体大小单位是相对于根元素(
html
)的字体大小计算的。 - 使用说明:根元素字体大小单位可以用于实现相对于根元素的自适应调整。例如,如果根元素的字体大小为
16px
,那么1rem
等于16px
。可以在根元素设置合适的字体大小,然后在其子元素中使用rem
单位来实现相对于根元素的尺寸调整。
- 相对单位:
em
:相对于父元素的字体大小。1em 等于父元素字体大小的 1倍。ex
:相对于字母 “x” 的高度。1ex 等于字母 “x” 的高度。ch
:相对于数字 “0” 的宽度。1ch 等于数字 “0” 的宽度。- 使用说明:相对单位通常用于相对于父元素的字体大小进行调整。例如,
font-size: 1.5em;
表示字体大小为父元素字体大小的 1.5 倍。
- 小程序中的单位
rpx
:
- 介绍:
rpx
是小程序中引入的尺寸单位,用于适配不同尺寸的手机屏幕。 - 使用说明:在小程序开发中,使用
rpx
单位可以在不同尺寸的手机屏幕上保持一致的显示效果。屏幕宽度为750rpx
,表示750
个响应式像素。例如,设置宽度为100rpx
,在屏幕宽度为375px
的手机上,它会被自动缩放为50px
。
通过合理选择不同的尺寸单位,可以实现页面的自适应和响应式设计,确保在不同设备上都能良好地展示内容。
5. img标签的title和alt有什么区别?
img
标签的 title
和 alt
属性都是用于提供关于图像的相关信息,但它们在功能和用途上有一些不同。
title
属性:
- 功能:
title
属性用于为图像提供附加的说明信息,通常以工具提示(tooltip)的形式显示在图像上,当用户将鼠标悬停在图像上时显示。 - 用途:
title
属性通常用于提供对图像的简短描述、相关链接的提示或其他补充说明,帮助用户更好地了解图像的内容或作用。 - 例子:
<img src="image.jpg" alt="Image Description" title="Click to enlarge" />
alt
属性:
- 功能:
alt
属性是img
标签的必需属性,用于为图像提供替代文本。当图像无法加载时,或者用户使用屏幕阅读器等辅助技术时,alt
属性中的文本将会显示出来,帮助用户理解图像的内容。 - 用途:
alt
属性用于提供对图像的描述性文本,以增强网页的可访问性,让用户在无法看到图像时仍能了解其内容。 - 例子:
<img src="image.jpg" alt="Image Description" />
需要注意的是,title
属性提供的提示信息是可选的,而 alt
属性是必需的。因此,alt
属性在网页中的使用是非常重要的,尤其对于需要符合无障碍(accessibility)标准的网页设计来说。同时,title
属性的使用应该谨慎,避免过度依赖 title
提供重要的信息,因为并不是所有用户都会悬停在图像上查看工具提示。
6. png、jpg、gif 、webp这些图片格式解释一下,分别什么时候用?
这里对几种常见的图片格式进行解释,并介绍它们在不同场景下的使用建议:
- PNG(Portable Network Graphics):
- 解释:PNG 是一种无损压缩的图片格式,支持透明度,可以呈现高质量的图像,特别适用于图标、图形和透明背景的图片。
- 使用建议:当需要保持图片质量并支持透明度时,特别是用于图标、图形或需要透明背景的图片时,推荐使用 PNG 格式。
- JPG(Joint Photographic Experts Group):
- 解释:JPG 是一种有损压缩的图片格式,适合用于存储照片或图像,能够在一定程度上减小文件大小,但可能会损失一些图像质量。
- 使用建议:当需要存储照片或带有丰富颜色的图像,并对文件大小有一定要求时,可以考虑使用 JPG 格式。
- GIF(Graphics Interchange Format):
- 解释:GIF 是一种支持动画的图片格式,它采用无损压缩算法,适用于制作简单的动画效果,但不适合存储复杂的图像。
- 使用建议:当需要制作简单的动画效果,如小型图标或简单的图形动画时,可以使用 GIF 格式。
- WebP:
- 解释:WebP 是由 Google 开发的一种图片格式,它同时支持有损和无损压缩,能够提供更小的文件大小和更高的图像质量。
- 使用建议:WebP 格式逐渐被广泛支持,特别适用于需要快速加载页面的场景,如网站中的图片。但需要注意的是,WebP 格式在部分老旧的浏览器上可能不支持,为了兼容性,可以使用
<picture>
元素或在服务器上进行图片格式转换。
总结使用建议:
- PNG:保持图片质量、支持透明度,适用于图标、图形和透明背景的图片。
- JPG:存储照片或图像,需要较小文件大小,适用于丰富颜色的图像。
- GIF:制作简单的动画效果,如小型图标或简单的图形动画。
- WebP:提供更小的文件大小和更高的图像质量,适用于需要快速加载页面的场景,但需注意兼容性。
7. 什么是语义化标签分别有哪些
语义化标签是指在编写 HTML 代码时,使用具有明确语义含义的标签来描述内容结构和意义,使得代码更易于理解、维护,并且能够增强页面的可访问性和搜索引擎优化(SEO)。使用语义化标签有助于让开发者和浏览器、搜索引擎等更好地理解页面的结构和内容。
以下是一些常见的语义化标签:
<header>
:用于表示页面或区块的页眉,通常包含标题、导航栏等内容。<nav>
:表示导航链接,用于包含页面的主导航。<main>
:表示文档的主要内容区域,一个页面应该只包含一个<main>
元素。<article>
:表示一个独立的、完整的文章或内容块,例如新闻、博客等。<section>
:表示文档中的一个区块或节,通常包含一组相关的内容。<aside>
:表示页面的侧边栏内容,通常与主要内容不直接相关。<footer>
:用于表示页面或区块的页脚,通常包含版权信息、联系方式等内容。<figure>
:表示文档中的一个图像、图表、照片等媒体对象,通常与它们的说明文本(<figcaption>
)结合使用。<figcaption>
:用于表示<figure>
元素的说明文本。<time>
:用于表示日期和时间,可以帮助搜索引擎理解日期时间信息。<cite>
:表示引用的标题或作品的名称。<blockquote>
:表示长的引用内容,通常带有缩进样式。<abbr>
:表示缩写或首字母缩略词。<code>
:表示计算机代码或编程代码。<kbd>
:表示键盘输入或命令。<mark>
:表示标记或突出显示的文本。
这些语义化标签可以让 HTML 文档更具有结构化和意义,同时也提高了可读性和维护性。使用适当的语义化标签有助于增强页面的可访问性,使得屏幕阅读器等辅助技术更好地理解网页内容,提升用户体验。另外,搜索引擎也会更好地理解页面结构和内容,从而提高网页在搜索结果中的排名。
8. ::before 和 :after中双冒号和单冒号 有什么区别?解释一下这2个伪元素的作用。
在 CSS 中,::before
和 ::after
是伪元素(pseudo-elements),用于在元素的内容前(::before
)或后(::after
)插入虚拟的内容。它们与伪类(pseudo-classes)(如 :hover
、:active
等)一样,允许我们在元素上添加样式,但它们是在元素的实际内容之前或之后插入的。
区别:
- 双冒号和单冒号的区别:
- 双冒号
::
表示伪元素,用于 CSS3 规范中引入的伪元素。 - 单冒号
:
表示伪类,早期的 CSS2 规范中用于伪元素和伪类都是单冒号,但为了区分,CSS3 中引入了双冒号来表示伪元素,保留单冒号用于伪类。
作用:
::before
伪元素:
- 用途:
::before
用于在选定元素的内容之前插入虚拟的内容。 - 常用于:常用于在元素前插入装饰性内容、图标或文字等,而无需在 HTML 结构中添加额外的标签。
::after
伪元素:
- 用途:
::after
用于在选定元素的内容之后插入虚拟的内容。 - 常用于:常用于在元素后插入装饰性内容、提示文本、清除浮动(clearfix)等功能。
示例代码:
<!DOCTYPE html> <html> <head> <style> /* 使用 ::before 插入内容 */ .example::before { content: "Before "; font-weight: bold; } /* 使用 ::after 插入内容 */ .example::after { content: " After"; font-style: italic; } </style> </head> <body> <div class="example">Content</div> </body> </html>
在上面的示例中,.example::before
伪元素插入了 "Before "
,.example::after
伪元素插入了 " After"
,使得最终显示在页面上的内容为 "Before Content After"
。
9. DOCTYPE(⽂档类型) 的作⽤
DOCTYPE(文档类型声明)是位于 HTML 文档开头的一个特殊标记,用于告诉浏览器当前文档使用的 HTML 版本。它的作用有以下几个方面:
- 告知浏览器文档类型:
- HTML 文档有多个版本(如 HTML4.01、HTML5 等),不同版本对标签和语法有不同的规定。DOCTYPE 声明告知浏览器当前文档所使用的 HTML 版本,让浏览器按照对应版本的规则来解析和渲染文档。
- 触发标准模式(Standards Mode):
- 在早期浏览器中,DOCTYPE 的作用主要是选择文档的渲染模式,区分标准模式和怪异模式(Quirks Mode)。标准模式下,浏览器按照规范来解析和渲染文档,而怪异模式下,浏览器会尽量模拟早期浏览器的行为,以兼容一些过时的页面。
- 在现代浏览器中,DOCTYPE 更多的用途是告知浏览器当前文档使用的 HTML 版本,而渲染模式的选择不再完全依赖于 DOCTYPE。
- 避免混乱模式(Quirks Mode):
- 在没有指定 DOCTYPE 或指定了不正确的 DOCTYPE 的情况下,浏览器可能进入混乱模式,这会导致页面在不同浏览器中显示不一致,或者与预期的显示效果不符。
在 HTML5 中,推荐使用简洁的 DOCTYPE 声明:
<!DOCTYPE html>
这个 DOCTYPE 声明是 HTML5 的标准模式的声明,它简洁明了,告诉浏览器当前文档使用的是 HTML5 版本。在现代的 Web 开发中,几乎所有的文档都会使用这个 DOCTYPE 声明,让页面以标准模式进行解析和渲染,以确保更好的兼容性和一致性。
10. 浏览器是如何对 HTML5 的离线储存资源进行管理和加载?
HTML5 提供了离线储存(Offline Storage)的特性,主要通过使用 `cache.manifest` 文件来指定需要离线缓存的资源。浏览器会根据 `cache.manifest` 文件中列出的资源列表,将这些资源缓存到本地,使得用户在离线状态下也能访问这些资源。 以下是浏览器对 HTML5 离线储存资源进行管理和加载的过程: 1. **创建 `cache.manifest` 文件**: - 开发者需要创建一个名为 `cache.manifest` 的文本文件,其中包含需要离线缓存的资源列表,以及其他配置信息。 2. **在 HTML 文件中引用 `cache.manifest` 文件**: - 在 HTML 文件的 `<html>` 标签中通过 `manifest` 属性引用 `cache.manifest` 文件。 - 示例:`<html manifest="cache.manifest">` 3. **浏览器解析 `cache.manifest` 文件**: - 当用户访问网页时,浏览器会解析 `cache.manifest` 文件,并根据文件中列出的资源列表进行缓存。 4. **初次加载**: - 首次访问网页时,浏览器会根据 `cache.manifest` 文件下载列出的所有资源,并将它们缓存到本地。 5. **后续加载**: - 一旦资源被缓存,以后再访问网页时,浏览器会先检查 `cache.manifest` 文件是否有更新。 - 如果 `cache.manifest` 文件没有更新,浏览器会直接从缓存中加载网页和所需的资源,使得网页能够离线访问。 - 如果 `cache.manifest` 文件有更新,浏览器会重新下载更新的资源,并更新缓存。 6. **清除缓存**: - 用户可以在浏览器设置中手动清除缓存,或者开发者可以通过更新 `cache.manifest` 文件的方式强制浏览器重新下载资源。 需要注意的是,使用离线储存的网页一般需要在服务器上托管,因为浏览器会通过服务器上的 `cache.manifest` 文件来管理和更新缓存。同时,由于浏览器对离线储存的实现在不同浏览器中可能会有差异,开发者在使用离线储存时需要进行充分的测试和兼容性考虑。