HTML 面试题错题总结与解析

本篇博客整理了本人在近期 HTML 面试题中的部分错误或薄弱问题。

第 1 题:如何在 HTML 中实现响应式图片加载?请举例说明 srcset 和 picture 的使用场景。

HTML 提供了 `srcset` 和 `<picture>` 两种方式来实现响应式图片加载。

方式一:使用 `srcset`:

```html

<img srcset="small.jpg 500w, medium.jpg 1000w, large.jpg 1500w"

sizes="(max-width: 600px) 500px, (max-width: 1200px) 1000px, 1500px"

src="fallback.jpg" alt="示例图片">

```

方式二:使用 `<picture>` 元素:

```html

<picture>

<source srcset="image.webp" type="image/webp">

<source srcset="image.jpg" type="image/jpeg">

<img src="image.jpg" alt="图片">

</picture>

```

第 2 题:如何在 HTML 中实现一个可访问性良好的表单?

  1. 使用 `<label>` 与输入框关联:

```html

<label for="email">邮箱:</label>

<input type="email" id="email" name="email">

```

  1. 使用 `<fieldset>` 和 `<legend>` 来组织表单组。

  2. 使用 `aria-*` 属性增强辅助技术识别能力。

第 3 题:解释 <label> 标签的作用,并说明它如何与表单控件关联。

`<label>` 标签可以让用户点击文字时聚焦对应表单控件。

```html

<label for="username">用户名</label>

<input type="text" id="username">

```

`for` 属性应绑定控件的 `id` 而非 `name`。

第 4 题:什么是块级元素和行内元素?请举出三个例子。

  • 块级元素:`<div>`、`<p>`、`<section>`

  • 行内元素:`<span>`、`<a>`、`<strong>`

`<input>` 是行内块元素(inline-block)

第 5 题:如何创建一个不可见但仍存在于 DOM 的元素?

```html

<div style="display:none;">隐藏内容</div>

<div hidden>隐藏内容</div>

<div style="visibility:hidden;">占位但不可见</div>

```

第 6 题:HTML5 中如何嵌入音频和视频?

```html

<audio controls>

<source src="audio.mp3" type="audio/mpeg">

您的浏览器不支持 audio 标签。

</audio>

<video controls width="320">

<source src="video.mp4" type="video/mp4">

您的浏览器不支持 video 标签。

</video>

```

第 7 题:ARIA 属性的作用以及你在什么情况下使用它。

ARIA 属性用于增强无障碍访问,例如:

  • `aria-label`:提供辅助说明

  • `aria-hidden="true"`:隐藏内容对读屏软件不可见

  • `role="button"`:声明元素的交互角色

  • `localStorage`:持久存储

  • `sessionStorage`:临时存储(关闭标签页即失效)

区别:本地存储不会自动随请求发送,容量更大,操作更简单

总结

通过本次错题整理发现,自己在 HTML 的可访问性、响应式图片、多媒体标签、ARIA 属性等方面还存在一定的理解偏差。

建议后续结合项目实际进行实践运用,并加强对 HTML5 新特性与浏览器行为的理解。

相关推荐
bjzhang751 分钟前
使用 HTML + JavaScript 实现滑动验证码
前端·javascript·html
行走的陀螺仪19 分钟前
使用uniapp,实现根据时间倒计时执行进度条变化
前端·javascript·uni-app·vue2·h5
科技D人生25 分钟前
Vue.js 学习总结(19)—— Vue3 按钮防重复点击三种方案总结
前端·vue.js·uniapp·vue3 防重复提交·uniapp 防重复提交·前端防抖
指尖跳动的光35 分钟前
前端视角-如何保证系统稳定性
前端
fruge37 分钟前
2025全栈技术深耕与实践:从框架融合到工程落地
前端
秋4271 小时前
tomcat与web服务器
服务器·前端·tomcat
hdsoft_huge1 小时前
Java 实现高效查询海量 geometry 及 Protobuf 序列化与天地图前端分片加载
java·前端·状态模式
MoonBit月兔1 小时前
用 MoonBit 打造的 Luna UI:日本开发者 mizchi 的 Web Components 实践
前端·数据库·mysql·ui·缓存·wasm·moonbit
程序员修心1 小时前
CSS浮动与表格布局全解析
前端·html
POLITE31 小时前
Leetcode 238.除了自身以外数组的乘积 JavaScript (Day 7)
前端·javascript·leetcode