为什么你不应该使用div作为可点击元素

微信搜索 【大迁世界】, 我会第一时间和你分享前端行业趋势,学习途径等等。 本文 GitHub github.com/qq449245884... 已收录,有一线大厂面试完整考点、资料以及我的系列文章。

新版作图神器已上线 cube.waixingyun.cn/home

按钮是为任何网络应用程序提供交互性的最常见方式。但我们经常倾向于使用其他HTML元素,如 div span 等作为 clickable 元素。

但通过这样做,我们错过了许多内置浏览器的功能。

我们缺少什么?

  1. 无障碍问题(空格键或回车键无法触发按钮点击)
  2. 元素将无法通过按Tab键来聚焦

权宜之计

我们需要在每次创建可点击的 div 按钮时,以编程方式添加所有这些功能

更好的解决方案

始终优先使用 button 作为可点击元素,以获取浏览器的所有内置功能,如果你没有使用它,始终将上述列出的可访问性功能添加到你的div中。

虽然,直接使用按钮并不直观。我们必须添加并修改一些默认的CSS和浏览器自带的行为。

使用按钮的注意事项

1. 它自带默认样式

我们可以通过将每个属性值设置为 unset 来取消设置现有的CSS。

我们可以添加 all:unset 一次性移除所有默认样式。

在HTML中,我们有三种类型的按钮。 submit, reset and button. 默认的按钮类型是 submit.

无论何时使用按钮,如果它不在表单内,请始终添加 type='button' ,因为 submit 和 reset 与表格有关。

2.请不要在按钮标签内部放置 divs

我们仍然需要添加 cursor:pointer 以便将光标更改为手形。

交流

有梦想,有干货,微信搜索 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。

本文 GitHub github.com/qq449245884... 已收录,有一线大厂面试完整考点、资料以及我的系列文章。

相关推荐
姜太公钓鲸23310 小时前
ROM就是程序存储器,实际的存储介质是Flash闪存。上述描述中的程序存储器是什么意思?
开发语言·javascript·ecmascript
柳杉11 小时前
使用AI从零打造炫酷医疗数据可视化大屏,源码免费拿!
前端·javascript·数据可视化
简单Janeee12 小时前
[Vue 3 从零到上线]-第四篇:组件化思维——把网页像积木一样拆解
javascript·vue.js·ecmascript
Heo13 小时前
深入React19任务调度器Scheduler
前端·javascript·面试
boooooooom13 小时前
Vue3 nextTick 实现大变化:微任务优先,彻底搞懂渲染时机!
javascript·vue.js·面试
用户144361834009713 小时前
你不知道的JS上-(九)
前端·javascript
冴羽14 小时前
2026 年 JavaScript 框架 3 大趋势
前端·javascript·react.js
思茂信息14 小时前
基于CST 3D Combined功能的以太网口RE仿真
开发语言·javascript·单片机·嵌入式硬件·matlab·3d
一拳不是超人15 小时前
从“必选项”到“性能包袱”:为什么现代框架开始“抛弃”虚拟 DOM?
前端·javascript·架构
Gogo112116 小时前
JavaScript 里的“空”:Null 与 Undefined 的终极指南
javascript