【vue】【element-plus】 el-date-picker使用cell-class-name进行标记,type=year不生效解决方法

type=dete ,自定义cell-class-name打标记效果如下:

相关代码:
bash 复制代码
        <el-date-picker
            v-model="date"
            :clearable="false"
            :editable="false"
            :cell-class-name="cellClassName"
            type="date"
            format="YYYY-MM-DD"
            value-format="YYYY-MM-DD"
        >
        </el-date-picker>


	//customDateArr : ['2025-04-01', '2025-04-23','2025-04-11']

      cellClassName:(date)=>{
        let that = this
        let nDate = parseTime(date, '{y}-{m}-{d}')//日期格式化方法
        // console.log(nDate)
        if (that.customDateArr.includes(nDate)) {
          return 'custom_date_class'; // 应用自定义样式类
        }
        return ''; // 其他日期不应用样式
      },
bash 复制代码
<style lang="scss">
.custom_date_class {
  span::after{
    content: "";
    position: absolute;
    width: 6px;
    height: 6px;
    background: var(--el-color-danger);
    border-radius: 50%;
    bottom: -5px;
    left: 50%;
    transform: translateX(-50%);
  }
}
</style>
type=year相关内容:

同样方法,当type=year时候,改成对应年份匹配后发现方法没有被调用,使用官方文档中的插槽方式(已升级到最新版)也无法实现。

最后通过焦点事件和面板更换事件直接操作dom元素进行强制赋值解决!!

bash 复制代码
<div class="select-center-left date-select">
        <el-date-picker
            popper-class="custom-year-picker"
            v-model="year"
            :clearable="false"
            :editable="false"
            type="year"
            value-format="YYYY"
            @focus="handleYearPickerOpen"
            @panel-change="handleYearPickerOpen"
            :disabled-date="disabledDate"
        />

const handleYearPickerOpen = () => {
  nextTick(() => {
    const pickerPanel = document.querySelector(' .custom-year-picker');
    // console.log(pickerPanel)
    if (pickerPanel) {
      const cells = pickerPanel.querySelectorAll('td');
      cells.forEach(cell => {
        // 示例:为 2023 年的单元格添加样式
        if (cell.textContent.includes('2023')||cell.textContent.includes('2019')) {
          cell.classList.add('custom_date_class');
        }else {
       		//不匹配需手动移除,否则切换面板后上次样式依旧存在
          	cell.classList.remove('custom_date_class')
        }
      });
    }
  });
};

类型为月份相关解决:element-ui的日期选择器cellClassName无效问题

相关推荐
贩卖纯净水.9 分钟前
浏览器兼容-polyfill-本地服务-优化
开发语言·前端·javascript
前端百草阁15 分钟前
从npm库 Vue 组件到独立SDK:打包与 CDN 引入的最佳实践
前端·vue.js·npm
夏日米米茶16 分钟前
Windows系统下npm报错node-gyp configure got “gyp ERR“解决方法
前端·windows·npm
且白1 小时前
vsCode使用本地低版本node启动配置文件
前端·vue.js·vscode·编辑器
程序研1 小时前
一、ES6-let声明变量【解刨分析最详细】
前端·javascript·es6
疯狂的沙粒1 小时前
在uni-app中如何从Options API迁移到Composition API?
javascript·vue.js·uni-app
siwangqishiq21 小时前
Vulkan Tutorial 教程翻译(四) 绘制三角形 2.2 呈现
前端
李三岁_foucsli1 小时前
js中消息队列和事件循环到底是怎么个事,宏任务和微任务还存在吗?
前端·chrome
尽欢i1 小时前
HTML5 拖放 API
前端·html
xiaominlaopodaren1 小时前
Three.js 光影魔法:如何单独点亮你的3D模型
javascript