menu与menuitem标签因浏览器支持差且被废弃,不推荐使用;应采用ul+li配合ARIA角色实现语义化、可访问的菜单结构。
HTML5 提供了更丰富的语义化标签来构建网页结构,但在实际开发中,menu 和 menuitem 这两个标签虽然被设计用于菜单场景,目前并不推荐在生产环境中使用,因为它们的浏览器支持有限且已被废弃或重新定义。
在早期 HTML5 草案中,menu 标签被用来定义用户命令菜单(如上下文菜单),配合 menuitem 表示具体的菜单项。但随着标准演进,该标签的实际用途被削弱。
menuitem 是一个完全未被广泛实现的元素,在现代 HTML 标准中已被删除。
案为了实现真正语义化、可访问且跨浏览器兼容的菜单,应使用标准结构和 ARIA 角色。
例如一个语义化的下拉菜单结构:
基本上就这些。虽然 menu 和 menuitem 听起来很合适,但现实是它们不可靠。坚持使用标准 HTML 列表结构加上 ARIA 才是实现语义化菜单的正确方式。不复杂但容易忽略。