
本文介绍如何用原生 javascript 构建轻量、可定制的月年选择器,重点解决初始化时年份显示错误(如默认显示 2024 而非当前年 2023)及当前年被误禁用的问题,并提供完整可运行代码与关键逻辑解析。
在开发表单或日期筛选功能时,标准 无法满足仅选择“年+月”的需求,而引入大型 UI 库又显得过度。此时,一个简洁、可控的自定义月年选择器(Month-Year Picker)是理想方案。本文将带你从零实现一个纯原生、无依赖的解决方案,并精准修复两个常见初始化缺陷:
- ✅ 页面加载时,默认应显示「当前年 + 当前月」(如 2023 年 7 月),而非错误地显示 2024 年;
- ✅ 当用户选择当前月份(如 7 月)时,当前年(2023)必须始终可用,不可被意外禁用。
? 核心问题根源:执行顺序导致状态错位
原始代码中,updateYearOptions() 在 updateMonthOptions() 之前调用:
updateYearOptions(); // ❌ 此时 month
由于