elementui日历展示节假日

记录一次需求,平台添加节假日,查看日历显示节假日

大概就长这样

dialog展示日历

<el-dialog title="日历" :visible.sync="openCalendar" width="90%" append-to-body>
      <el-row :gutter="20" style="display: flex; flex-wrap: wrap;">
        <el-col :span="4" v-for="(month,index) in calendar">
          <el-card class="box-card">
            <div slot="header" class="clearfix">
              <span>{{index+1}}月</span>
            </div>
            <div>
              <table class="el-date-table">
                <tbody>
                <tr>
                  <th>日</th><th>一</th><th>二</th><th>三</th><th>四</th><th>五</th><th>六</th>
                </tr>
                <tr class="el-date-table__row" v-for="week in month">
                  <td :class="day.month === index+1?'available':'prev-month'" v-for="(day,ind) in week">
                      <div :style="(day.month !== index+1)?'':(day.holiday?'background-color: #eeee25;':(ind===0||ind===6?'background-color: rgb(245 130 130);':'background-color: #f5f7fa;'))">
                        <el-tooltip :content="day.holidayName" placement="top" v-if="day.holiday">
                          <span>{{day.day}}</span>
                        </el-tooltip>
                        <span v-else>{{day.day}}</span>
                      </div>
                  </td>
                </tr>
                </tbody>
              </table>
            </div>
          </el-card>
        </el-col>
      </el-row>
      <div slot="footer" class="dialog-footer">
        <el-button @click="cancelCalendar">关闭</el-button>
      </div>
    </el-dialog>

data相关

data() {
    return {
        calendar:[[[{"day":31,"holiday":false,"localDate":"2023-12-31","month":12,"year":2023},{"day":1,"holiday":true,"holidayName":"元旦","localDate":"2024-01-01","month":1,"year":2024},{"day":2,"holiday":false,"localDate":"2024-01-02","month":1,"year":2024},{"day":3,"holiday":false,"localDate":"2024-01-03","month":1,"year":2024},{"day":4,"holiday":false,"localDate":"2024-01-04","month":1,"year":2024},{"day":5,"holiday":false,"localDate":"2024-01-05","month":1,"year":2024},{"day":6,"holiday":false,"localDate":"2024-01-06","month":1,"year":2024}],[{"day":7,"holiday":false,"localDate":"2024-01-07","month":1,"year":2024},{"day":8,"holiday":false,"localDate":"2024-01-08","month":1,"year":2024},{"day":9,"holiday":false,"localDate":"2024-01-09","month":1,"year":2024},{"day":10,"holiday":false,"localDate":"2024-01-10","month":1,"year":2024},{"day":11,"holiday":false,"localDate":"2024-01-11","month":1,"year":2024},{"day":12,"holiday":false,"localDate":"2024-01-12","month":1,"year":2024},{"day":13,"holiday":false,"localDate":"2024-01-13","month":1,"year":2024}],[{"day":14,"holiday":false,"localDate":"2024-01-14","month":1,"year":2024},{"day":15,"holiday":false,"localDate":"2024-01-15","month":1,"year":2024},{"day":16,"holiday":false,"localDate":"2024-01-16","month":1,"year":2024},{"day":17,"holiday":false,"localDate":"2024-01-17","month":1,"year":2024},{"day":18,"holiday":false,"localDate":"2024-01-18","month":1,"year":2024},{"day":19,"holiday":false,"localDate":"2024-01-19","month":1,"year":2024},{"day":20,"holiday":false,"localDate":"2024-01-20","month":1,"year":2024}],[{"day":21,"holiday":false,"localDate":"2024-01-21","month":1,"year":2024},{"day":22,"holiday":false,"localDate":"2024-01-22","month":1,"year":2024},{"day":23,"holiday":false,"localDate":"2024-01-23","month":1,"year":2024},{"day":24,"holiday":false,"localDate":"2024-01-24","month":1,"year":2024},{"day":25,"holiday":false,"localDate":"2024-01-25","month":1,"year":2024},{"day":26,"holiday":false,"localDate":"2024-01-26","month":1,"year":2024},{"day":27,"holiday":false,"localDate":"2024-01-27","month":1,"year":2024}],[{"day":28,"holiday":false,"localDate":"2024-01-28","month":1,"year":2024},{"day":29,"holiday":false,"localDate":"2024-01-29","month":1,"year":2024},{"day":30,"holiday":false,"localDate":"2024-01-30","month":1,"year":2024},{"day":31,"holiday":false,"localDate":"2024-01-31","month":1,"year":2024},{"day":1,"holiday":false,"localDate":"2024-02-01","month":2,"year":2024},{"day":2,"holiday":false,"localDate":"2024-02-02","month":2,"year":2024},{"day":3,"holiday":false,"localDate":"2024-02-03","month":2,"year":2024}]],[[{"day":28,"holiday":false,"localDate":"2024-01-28","month":1,"year":2024},{"day":29,"holiday":false,"localDate":"2024-01-29","month":1,"year":2024},{"day":30,"holiday":false,"localDate":"2024-01-30","month":1,"year":2024},{"day":31,"holiday":false,"localDate":"2024-01-31","month":1,"year":2024},{"day":1,"holiday":false,"localDate":"2024-02-01","month":2,"year":2024},{"day":2,"holiday":false,"localDate":"2024-02-02","month":2,"year":2024},{"day":3,"holiday":false,"localDate":"2024-02-03","month":2,"year":2024}],[{"day":4,"holiday":false,"localDate":"2024-02-04","month":2,"year":2024},{"day":5,"holiday":false,"localDate":"2024-02-05","month":2,"year":2024},{"day":6,"holiday":false,"localDate":"2024-02-06","month":2,"year":2024},{"day":7,"holiday":false,"localDate":"2024-02-07","month":2,"year":2024},{"day":8,"holiday":false,"localDate":"2024-02-08","month":2,"year":2024},{"day":9,"holiday":false,"localDate":"2024-02-09","month":2,"year":2024},{"day":10,"holiday":false,"localDate":"2024-02-10","month":2,"year":2024}],[{"day":11,"holiday":false,"localDate":"2024-02-11","month":2,"year":2024},{"day":12,"holiday":false,"localDate":"2024-02-12","month":2,"year":2024},{"day":13,"holiday":false,"localDate":"2024-02-13","month":2,"year":2024},{"day":14,"holiday":false,"localDate":"2024-02-14","month":2,"year":2024},{"day":15,"holiday":false,"localDate":"2024-02-15","month":2,"year":2024},{"day":16,"holiday":false,"localDate":"2024-02-16","month":2,"year":2024},{"day":17,"holiday":false,"localDate":"2024-02-17","month":2,"year":2024}],[{"day":18,"holiday":false,"localDate":"2024-02-18","month":2,"year":2024},{"day":19,"holiday":false,"localDate":"2024-02-19","month":2,"year":2024},{"day":20,"holiday":false,"localDate":"2024-02-20","month":2,"year":2024},{"day":21,"holiday":false,"localDate":"2024-02-21","month":2,"year":2024},{"day":22,"holiday":false,"localDate":"2024-02-22","month":2,"year":2024},{"day":23,"holiday":false,"localDate":"2024-02-23","month":2,"year":2024},{"day":24,"holiday":false,"localDate":"2024-02-24","month":2,"year":2024}],[{"day":25,"holiday":false,"localDate":"2024-02-25","month":2,"year":2024},{"day":26,"holiday":false,"localDate":"2024-02-26","month":2,"year":2024},{"day":27,"holiday":false,"localDate":"2024-02-27","month":2,"year":2024},{"day":28,"holiday":false,"localDate":"2024-02-28","month":2,"year":2024},{"day":29,"holiday":false,"localDate":"2024-02-29","month":2,"year":2024},{"day":1,"holiday":false,"localDate":"2024-03-01","month":3,"year":2024},{"day":2,"holiday":false,"localDate":"2024-03-02","month":3,"year":2024}]],[[{"day":25,"holiday":false,"localDate":"2024-02-25","month":2,"year":2024},{"day":26,"holiday":false,"localDate":"2024-02-26","month":2,"year":2024},{"day":27,"holiday":false,"localDate":"2024-02-27","month":2,"year":2024},{"day":28,"holiday":false,"localDate":"2024-02-28","month":2,"year":2024},{"day":29,"holiday":false,"localDate":"2024-02-29","month":2,"year":2024},{"day":1,"holiday":false,"localDate":"2024-03-01","month":3,"year":2024},{"day":2,"holiday":false,"localDate":"2024-03-02","month":3,"year":2024}],[{"day":3,"holiday":false,"localDate":"2024-03-03","month":3,"year":2024},{"day":4,"holiday":false,"localDate":"2024-03-04","month":3,"year":2024},{"day":5,"holiday":false,"localDate":"2024-03-05","month":3,"year":2024},{"day":6,"holiday":false,"localDate":"2024-03-06","month":3,"year":2024},{"day":7,"holiday":false,"localDate":"2024-03-07","month":3,"year":2024},{"day":8,"holiday":false,"localDate":"2024-03-08","month":3,"year":2024},{"day":9,"holiday":false,"localDate":"2024-03-09","month":3,"year":2024}],[{"day":10,"holiday":false,"localDate":"2024-03-10","month":3,"year":2024},{"day":11,"holiday":false,"localDate":"2024-03-11","month":3,"year":2024},{"day":12,"holiday":false,"localDate":"2024-03-12","month":3,"year":2024},{"day":13,"holiday":false,"localDate":"2024-03-13","month":3,"year":2024},{"day":14,"holiday":false,"localDate":"2024-03-14","month":3,"year":2024},{"day":15,"holiday":false,"localDate":"2024-03-15","month":3,"year":2024},{"day":16,"holiday":false,"localDate":"2024-03-16","month":3,"year":2024}],[{"day":17,"holiday":false,"localDate":"2024-03-17","month":3,"year":2024},{"day":18,"holiday":false,"localDate":"2024-03-18","month":3,"year":2024},{"day":19,"holiday":false,"localDate":"2024-03-19","month":3,"year":2024},{"day":20,"holiday":false,"localDate":"2024-03-20","month":3,"year":2024},{"day":21,"holiday":false,"localDate":"2024-03-21","month":3,"year":2024},{"day":22,"holiday":false,"localDate":"2024-03-22","month":3,"year":2024},{"day":23,"holiday":false,"localDate":"2024-03-23","month":3,"year":2024}],[{"day":24,"holiday":false,"localDate":"2024-03-24","month":3,"year":2024},{"day":25,"holiday":false,"localDate":"2024-03-25","month":3,"year":2024},{"day":26,"holiday":false,"localDate":"2024-03-26","month":3,"year":2024},{"day":27,"holiday":false,"localDate":"2024-03-27","month":3,"year":2024},{"day":28,"holiday":false,"localDate":"2024-03-28","month":3,"year":2024},{"day":29,"holiday":false,"localDate":"2024-03-29","month":3,"year":2024},{"day":30,"holiday":false,"localDate":"2024-03-30","month":3,"year":2024}],[{"day":31,"holiday":false,"localDate":"2024-03-31","month":3,"year":2024},{"day":1,"holiday":false,"localDate":"2024-04-01","month":4,"year":2024},{"day":2,"holiday":false,"localDate":"2024-04-02","month":4,"year":2024},{"day":3,"holiday":false,"localDate":"2024-04-03","month":4,"year":2024},{"day":4,"holiday":false,"localDate":"2024-04-04","month":4,"year":2024},{"day":5,"holiday":false,"localDate":"2024-04-05","month":4,"year":2024},{"day":6,"holiday":false,"localDate":"2024-04-06","month":4,"year":2024}]],[[{"day":31,"holiday":false,"localDate":"2024-03-31","month":3,"year":2024},{"day":1,"holiday":false,"localDate":"2024-04-01","month":4,"year":2024},{"day":2,"holiday":false,"localDate":"2024-04-02","month":4,"year":2024},{"day":3,"holiday":false,"localDate":"2024-04-03","month":4,"year":2024},{"day":4,"holiday":false,"localDate":"2024-04-04","month":4,"year":2024},{"day":5,"holiday":false,"localDate":"2024-04-05","month":4,"year":2024},{"day":6,"holiday":false,"localDate":"2024-04-06","month":4,"year":2024}],[{"day":7,"holiday":false,"localDate":"2024-04-07","month":4,"year":2024},{"day":8,"holiday":false,"localDate":"2024-04-08","month":4,"year":2024},{"day":9,"holiday":false,"localDate":"2024-04-09","month":4,"year":2024},{"day":10,"holiday":false,"localDate":"2024-04-10","month":4,"year":2024},{"day":11,"holiday":false,"localDate":"2024-04-11","month":4,"year":2024},{"day":12,"holiday":false,"localDate":"2024-04-12","month":4,"year":2024},{"day":13,"holiday":false,"localDate":"2024-04-13","month":4,"year":2024}],[{"day":14,"holiday":false,"localDate":"2024-04-14","month":4,"year":2024},{"day":15,"holiday":false,"localDate":"2024-04-15","month":4,"year":2024},{"day":16,"holiday":false,"localDate":"2024-04-16","month":4,"year":2024},{"day":17,"holiday":false,"localDate":"2024-04-17","month":4,"year":2024},{"day":18,"holiday":false,"localDate":"2024-04-18","month":4,"year":2024},{"day":19,"holiday":false,"localDate":"2024-04-19","month":4,"year":2024},{"day":20,"holiday":false,"localDate":"2024-04-20","month":4,"year":2024}],[{"day":21,"holiday":false,"localDate":"2024-04-21","month":4,"year":2024},{"day":22,"holiday":false,"localDate":"2024-04-22","month":4,"year":2024},{"day":23,"holiday":false,"localDate":"2024-04-23","month":4,"year":2024},{"day":24,"holiday":false,"localDate":"2024-04-24","month":4,"year":2024},{"day":25,"holiday":false,"localDate":"2024-04-25","month":4,"year":2024},{"day":26,"holiday":false,"localDate":"2024-04-26","month":4,"year":2024},{"day":27,"holiday":false,"localDate":"2024-04-27","month":4,"year":2024}],[{"day":28,"holiday":false,"localDate":"2024-04-28","month":4,"year":2024},{"day":29,"holiday":false,"localDate":"2024-04-29","month":4,"year":2024},{"day":30,"holiday":false,"localDate":"2024-04-30","month":4,"year":2024},{"day":1,"holiday":false,"localDate":"2024-05-01","month":5,"year":2024},{"day":2,"holiday":false,"localDate":"2024-05-02","month":5,"year":2024},{"day":3,"holiday":false,"localDate":"2024-05-03","month":5,"year":2024},{"day":4,"holiday":false,"localDate":"2024-05-04","month":5,"year":2024}]],[[{"day":28,"holiday":false,"localDate":"2024-04-28","month":4,"year":2024},{"day":29,"holiday":false,"localDate":"2024-04-29","month":4,"year":2024},{"day":30,"holiday":false,"localDate":"2024-04-30","month":4,"year":2024},{"day":1,"holiday":false,"localDate":"2024-05-01","month":5,"year":2024},{"day":2,"holiday":false,"localDate":"2024-05-02","month":5,"year":2024},{"day":3,"holiday":false,"localDate":"2024-05-03","month":5,"year":2024},{"day":4,"holiday":false,"localDate":"2024-05-04","month":5,"year":2024}],[{"day":5,"holiday":false,"localDate":"2024-05-05","month":5,"year":2024},{"day":6,"holiday":false,"localDate":"2024-05-06","month":5,"year":2024},{"day":7,"holiday":false,"localDate":"2024-05-07","month":5,"year":2024},{"day":8,"holiday":false,"localDate":"2024-05-08","month":5,"year":2024},{"day":9,"holiday":false,"localDate":"2024-05-09","month":5,"year":2024},{"day":10,"holiday":false,"localDate":"2024-05-10","month":5,"year":2024},{"day":11,"holiday":false,"localDate":"2024-05-11","month":5,"year":2024}],[{"day":12,"holiday":false,"localDate":"2024-05-12","month":5,"year":2024},{"day":13,"holiday":false,"localDate":"2024-05-13","month":5,"year":2024},{"day":14,"holiday":false,"localDate":"2024-05-14","month":5,"year":2024},{"day":15,"holiday":false,"localDate":"2024-05-15","month":5,"year":2024},{"day":16,"holiday":false,"localDate":"2024-05-16","month":5,"year":2024},{"day":17,"holiday":false,"localDate":"2024-05-17","month":5,"year":2024},{"day":18,"holiday":false,"localDate":"2024-05-18","month":5,"year":2024}],[{"day":19,"holiday":false,"localDate":"2024-05-19","month":5,"year":2024},{"day":20,"holiday":false,"localDate":"2024-05-20","month":5,"year":2024},{"day":21,"holiday":false,"localDate":"2024-05-21","month":5,"year":2024},{"day":22,"holiday":false,"localDate":"2024-05-22","month":5,"year":2024},{"day":23,"holiday":false,"localDate":"2024-05-23","month":5,"year":2024},{"day":24,"holiday":false,"localDate":"2024-05-24","month":5,"year":2024},{"day":25,"holiday":false,"localDate":"2024-05-25","month":5,"year":2024}],[{"day":26,"holiday":false,"localDate":"2024-05-26","month":5,"year":2024},{"day":27,"holiday":false,"localDate":"2024-05-27","month":5,"year":2024},{"day":28,"holiday":false,"localDate":"2024-05-28","month":5,"year":2024},{"day":29,"holiday":false,"localDate":"2024-05-29","month":5,"year":2024},{"day":30,"holiday":false,"localDate":"2024-05-30","month":5,"year":2024},{"day":31,"holiday":false,"localDate":"2024-05-31","month":5,"year":2024},{"day":1,"holiday":false,"localDate":"2024-06-01","month":6,"year":2024}]],[[{"day":26,"holiday":false,"localDate":"2024-05-26","month":5,"year":2024},{"day":27,"holiday":false,"localDate":"2024-05-27","month":5,"year":2024},{"day":28,"holiday":false,"localDate":"2024-05-28","month":5,"year":2024},{"day":29,"holiday":false,"localDate":"2024-05-29","month":5,"year":2024},{"day":30,"holiday":false,"localDate":"2024-05-30","month":5,"year":2024},{"day":31,"holiday":false,"localDate":"2024-05-31","month":5,"year":2024},{"day":1,"holiday":false,"localDate":"2024-06-01","month":6,"year":2024}],[{"day":2,"holiday":false,"localDate":"2024-06-02","month":6,"year":2024},{"day":3,"holiday":false,"localDate":"2024-06-03","month":6,"year":2024},{"day":4,"holiday":false,"localDate":"2024-06-04","month":6,"year":2024},{"day":5,"holiday":false,"localDate":"2024-06-05","month":6,"year":2024},{"day":6,"holiday":false,"localDate":"2024-06-06","month":6,"year":2024},{"day":7,"holiday":false,"localDate":"2024-06-07","month":6,"year":2024},{"day":8,"holiday":false,"localDate":"2024-06-08","month":6,"year":2024}],[{"day":9,"holiday":false,"localDate":"2024-06-09","month":6,"year":2024},{"day":10,"holiday":false,"localDate":"2024-06-10","month":6,"year":2024},{"day":11,"holiday":false,"localDate":"2024-06-11","month":6,"year":2024},{"day":12,"holiday":false,"localDate":"2024-06-12","month":6,"year":2024},{"day":13,"holiday":false,"localDate":"2024-06-13","month":6,"year":2024},{"day":14,"holiday":false,"localDate":"2024-06-14","month":6,"year":2024},{"day":15,"holiday":false,"localDate":"2024-06-15","month":6,"year":2024}],[{"day":16,"holiday":false,"localDate":"2024-06-16","month":6,"year":2024},{"day":17,"holiday":false,"localDate":"2024-06-17","month":6,"year":2024},{"day":18,"holiday":false,"localDate":"2024-06-18","month":6,"year":2024},{"day":19,"holiday":false,"localDate":"2024-06-19","month":6,"year":2024},{"day":20,"holiday":false,"localDate":"2024-06-20","month":6,"year":2024},{"day":21,"holiday":false,"localDate":"2024-06-21","month":6,"year":2024},{"day":22,"holiday":false,"localDate":"2024-06-22","month":6,"year":2024}],[{"day":23,"holiday":false,"localDate":"2024-06-23","month":6,"year":2024},{"day":24,"holiday":false,"localDate":"2024-06-24","month":6,"year":2024},{"day":25,"holiday":false,"localDate":"2024-06-25","month":6,"year":2024},{"day":26,"holiday":false,"localDate":"2024-06-26","month":6,"year":2024},{"day":27,"holiday":false,"localDate":"2024-06-27","month":6,"year":2024},{"day":28,"holiday":false,"localDate":"2024-06-28","month":6,"year":2024},{"day":29,"holiday":false,"localDate":"2024-06-29","month":6,"year":2024}],[{"day":30,"holiday":false,"localDate":"2024-06-30","month":6,"year":2024},{"day":1,"holiday":false,"localDate":"2024-07-01","month":7,"year":2024},{"day":2,"holiday":false,"localDate":"2024-07-02","month":7,"year":2024},{"day":3,"holiday":false,"localDate":"2024-07-03","month":7,"year":2024},{"day":4,"holiday":false,"localDate":"2024-07-04","month":7,"year":2024},{"day":5,"holiday":false,"localDate":"2024-07-05","month":7,"year":2024},{"day":6,"holiday":false,"localDate":"2024-07-06","month":7,"year":2024}]],[[{"day":30,"holiday":false,"localDate":"2024-06-30","month":6,"year":2024},{"day":1,"holiday":false,"localDate":"2024-07-01","month":7,"year":2024},{"day":2,"holiday":false,"localDate":"2024-07-02","month":7,"year":2024},{"day":3,"holiday":false,"localDate":"2024-07-03","month":7,"year":2024},{"day":4,"holiday":false,"localDate":"2024-07-04","month":7,"year":2024},{"day":5,"holiday":false,"localDate":"2024-07-05","month":7,"year":2024},{"day":6,"holiday":false,"localDate":"2024-07-06","month":7,"year":2024}],[{"day":7,"holiday":false,"localDate":"2024-07-07","month":7,"year":2024},{"day":8,"holiday":false,"localDate":"2024-07-08","month":7,"year":2024},{"day":9,"holiday":false,"localDate":"2024-07-09","month":7,"year":2024},{"day":10,"holiday":false,"localDate":"2024-07-10","month":7,"year":2024},{"day":11,"holiday":false,"localDate":"2024-07-11","month":7,"year":2024},{"day":12,"holiday":false,"localDate":"2024-07-12","month":7,"year":2024},{"day":13,"holiday":false,"localDate":"2024-07-13","month":7,"year":2024}],[{"day":14,"holiday":false,"localDate":"2024-07-14","month":7,"year":2024},{"day":15,"holiday":false,"localDate":"2024-07-15","month":7,"year":2024},{"day":16,"holiday":false,"localDate":"2024-07-16","month":7,"year":2024},{"day":17,"holiday":false,"localDate":"2024-07-17","month":7,"year":2024},{"day":18,"holiday":false,"localDate":"2024-07-18","month":7,"year":2024},{"day":19,"holiday":false,"localDate":"2024-07-19","month":7,"year":2024},{"day":20,"holiday":false,"localDate":"2024-07-20","month":7,"year":2024}],[{"day":21,"holiday":false,"localDate":"2024-07-21","month":7,"year":2024},{"day":22,"holiday":false,"localDate":"2024-07-22","month":7,"year":2024},{"day":23,"holiday":false,"localDate":"2024-07-23","month":7,"year":2024},{"day":24,"holiday":false,"localDate":"2024-07-24","month":7,"year":2024},{"day":25,"holiday":false,"localDate":"2024-07-25","month":7,"year":2024},{"day":26,"holiday":false,"localDate":"2024-07-26","month":7,"year":2024},{"day":27,"holiday":false,"localDate":"2024-07-27","month":7,"year":2024}],[{"day":28,"holiday":false,"localDate":"2024-07-28","month":7,"year":2024},{"day":29,"holiday":false,"localDate":"2024-07-29","month":7,"year":2024},{"day":30,"holiday":false,"localDate":"2024-07-30","month":7,"year":2024},{"day":31,"holiday":false,"localDate":"2024-07-31","month":7,"year":2024},{"day":1,"holiday":false,"localDate":"2024-08-01","month":8,"year":2024},{"day":2,"holiday":false,"localDate":"2024-08-02","month":8,"year":2024},{"day":3,"holiday":false,"localDate":"2024-08-03","month":8,"year":2024}]],[[{"day":28,"holiday":false,"localDate":"2024-07-28","month":7,"year":2024},{"day":29,"holiday":false,"localDate":"2024-07-29","month":7,"year":2024},{"day":30,"holiday":false,"localDate":"2024-07-30","month":7,"year":2024},{"day":31,"holiday":false,"localDate":"2024-07-31","month":7,"year":2024},{"day":1,"holiday":false,"localDate":"2024-08-01","month":8,"year":2024},{"day":2,"holiday":false,"localDate":"2024-08-02","month":8,"year":2024},{"day":3,"holiday":false,"localDate":"2024-08-03","month":8,"year":2024}],[{"day":4,"holiday":false,"localDate":"2024-08-04","month":8,"year":2024},{"day":5,"holiday":false,"localDate":"2024-08-05","month":8,"year":2024},{"day":6,"holiday":false,"localDate":"2024-08-06","month":8,"year":2024},{"day":7,"holiday":false,"localDate":"2024-08-07","month":8,"year":2024},{"day":8,"holiday":false,"localDate":"2024-08-08","month":8,"year":2024},{"day":9,"holiday":false,"localDate":"2024-08-09","month":8,"year":2024},{"day":10,"holiday":false,"localDate":"2024-08-10","month":8,"year":2024}],[{"day":11,"holiday":false,"localDate":"2024-08-11","month":8,"year":2024},{"day":12,"holiday":false,"localDate":"2024-08-12","month":8,"year":2024},{"day":13,"holiday":false,"localDate":"2024-08-13","month":8,"year":2024},{"day":14,"holiday":false,"localDate":"2024-08-14","month":8,"year":2024},{"day":15,"holiday":false,"localDate":"2024-08-15","month":8,"year":2024},{"day":16,"holiday":false,"localDate":"2024-08-16","month":8,"year":2024},{"day":17,"holiday":false,"localDate":"2024-08-17","month":8,"year":2024}],[{"day":18,"holiday":false,"localDate":"2024-08-18","month":8,"year":2024},{"day":19,"holiday":false,"localDate":"2024-08-19","month":8,"year":2024},{"day":20,"holiday":false,"localDate":"2024-08-20","month":8,"year":2024},{"day":21,"holiday":false,"localDate":"2024-08-21","month":8,"year":2024},{"day":22,"holiday":false,"localDate":"2024-08-22","month":8,"year":2024},{"day":23,"holiday":false,"localDate":"2024-08-23","month":8,"year":2024},{"day":24,"holiday":false,"localDate":"2024-08-24","month":8,"year":2024}],[{"day":25,"holiday":false,"localDate":"2024-08-25","month":8,"year":2024},{"day":26,"holiday":false,"localDate":"2024-08-26","month":8,"year":2024},{"day":27,"holiday":false,"localDate":"2024-08-27","month":8,"year":2024},{"day":28,"holiday":false,"localDate":"2024-08-28","month":8,"year":2024},{"day":29,"holiday":false,"localDate":"2024-08-29","month":8,"year":2024},{"day":30,"holiday":false,"localDate":"2024-08-30","month":8,"year":2024},{"day":31,"holiday":false,"localDate":"2024-08-31","month":8,"year":2024}]],[[{"day":1,"holiday":false,"localDate":"2024-09-01","month":9,"year":2024},{"day":2,"holiday":false,"localDate":"2024-09-02","month":9,"year":2024},{"day":3,"holiday":false,"localDate":"2024-09-03","month":9,"year":2024},{"day":4,"holiday":false,"localDate":"2024-09-04","month":9,"year":2024},{"day":5,"holiday":false,"localDate":"2024-09-05","month":9,"year":2024},{"day":6,"holiday":false,"localDate":"2024-09-06","month":9,"year":2024},{"day":7,"holiday":false,"localDate":"2024-09-07","month":9,"year":2024}],[{"day":8,"holiday":false,"localDate":"2024-09-08","month":9,"year":2024},{"day":9,"holiday":false,"localDate":"2024-09-09","month":9,"year":2024},{"day":10,"holiday":false,"localDate":"2024-09-10","month":9,"year":2024},{"day":11,"holiday":false,"localDate":"2024-09-11","month":9,"year":2024},{"day":12,"holiday":false,"localDate":"2024-09-12","month":9,"year":2024},{"day":13,"holiday":false,"localDate":"2024-09-13","month":9,"year":2024},{"day":14,"holiday":false,"localDate":"2024-09-14","month":9,"year":2024}],[{"day":15,"holiday":false,"localDate":"2024-09-15","month":9,"year":2024},{"day":16,"holiday":false,"localDate":"2024-09-16","month":9,"year":2024},{"day":17,"holiday":false,"localDate":"2024-09-17","month":9,"year":2024},{"day":18,"holiday":false,"localDate":"2024-09-18","month":9,"year":2024},{"day":19,"holiday":false,"localDate":"2024-09-19","month":9,"year":2024},{"day":20,"holiday":false,"localDate":"2024-09-20","month":9,"year":2024},{"day":21,"holiday":false,"localDate":"2024-09-21","month":9,"year":2024}],[{"day":22,"holiday":false,"localDate":"2024-09-22","month":9,"year":2024},{"day":23,"holiday":false,"localDate":"2024-09-23","month":9,"year":2024},{"day":24,"holiday":false,"localDate":"2024-09-24","month":9,"year":2024},{"day":25,"holiday":false,"localDate":"2024-09-25","month":9,"year":2024},{"day":26,"holiday":false,"localDate":"2024-09-26","month":9,"year":2024},{"day":27,"holiday":false,"localDate":"2024-09-27","month":9,"year":2024},{"day":28,"holiday":false,"localDate":"2024-09-28","month":9,"year":2024}],[{"day":29,"holiday":false,"localDate":"2024-09-29","month":9,"year":2024},{"day":30,"holiday":false,"localDate":"2024-09-30","month":9,"year":2024},{"day":1,"holiday":true,"holidayName":"国庆节","localDate":"2024-10-01","month":10,"year":2024},{"day":2,"holiday":true,"holidayName":"国庆节","localDate":"2024-10-02","month":10,"year":2024},{"day":3,"holiday":true,"holidayName":"国庆节","localDate":"2024-10-03","month":10,"year":2024},{"day":4,"holiday":false,"localDate":"2024-10-04","month":10,"year":2024},{"day":5,"holiday":false,"localDate":"2024-10-05","month":10,"year":2024}]],[[{"day":29,"holiday":false,"localDate":"2024-09-29","month":9,"year":2024},{"day":30,"holiday":false,"localDate":"2024-09-30","month":9,"year":2024},{"day":1,"holiday":true,"holidayName":"国庆节","localDate":"2024-10-01","month":10,"year":2024},{"day":2,"holiday":true,"holidayName":"国庆节","localDate":"2024-10-02","month":10,"year":2024},{"day":3,"holiday":true,"holidayName":"国庆节","localDate":"2024-10-03","month":10,"year":2024},{"day":4,"holiday":false,"localDate":"2024-10-04","month":10,"year":2024},{"day":5,"holiday":false,"localDate":"2024-10-05","month":10,"year":2024}],[{"day":6,"holiday":false,"localDate":"2024-10-06","month":10,"year":2024},{"day":7,"holiday":false,"localDate":"2024-10-07","month":10,"year":2024},{"day":8,"holiday":false,"localDate":"2024-10-08","month":10,"year":2024},{"day":9,"holiday":false,"localDate":"2024-10-09","month":10,"year":2024},{"day":10,"holiday":false,"localDate":"2024-10-10","month":10,"year":2024},{"day":11,"holiday":false,"localDate":"2024-10-11","month":10,"year":2024},{"day":12,"holiday":false,"localDate":"2024-10-12","month":10,"year":2024}],[{"day":13,"holiday":false,"localDate":"2024-10-13","month":10,"year":2024},{"day":14,"holiday":false,"localDate":"2024-10-14","month":10,"year":2024},{"day":15,"holiday":false,"localDate":"2024-10-15","month":10,"year":2024},{"day":16,"holiday":false,"localDate":"2024-10-16","month":10,"year":2024},{"day":17,"holiday":false,"localDate":"2024-10-17","month":10,"year":2024},{"day":18,"holiday":false,"localDate":"2024-10-18","month":10,"year":2024},{"day":19,"holiday":false,"localDate":"2024-10-19","month":10,"year":2024}],[{"day":20,"holiday":false,"localDate":"2024-10-20","month":10,"year":2024},{"day":21,"holiday":false,"localDate":"2024-10-21","month":10,"year":2024},{"day":22,"holiday":false,"localDate":"2024-10-22","month":10,"year":2024},{"day":23,"holiday":false,"localDate":"2024-10-23","month":10,"year":2024},{"day":24,"holiday":false,"localDate":"2024-10-24","month":10,"year":2024},{"day":25,"holiday":false,"localDate":"2024-10-25","month":10,"year":2024},{"day":26,"holiday":false,"localDate":"2024-10-26","month":10,"year":2024}],[{"day":27,"holiday":false,"localDate":"2024-10-27","month":10,"year":2024},{"day":28,"holiday":false,"localDate":"2024-10-28","month":10,"year":2024},{"day":29,"holiday":false,"localDate":"2024-10-29","month":10,"year":2024},{"day":30,"holiday":false,"localDate":"2024-10-30","month":10,"year":2024},{"day":31,"holiday":false,"localDate":"2024-10-31","month":10,"year":2024},{"day":1,"holiday":false,"localDate":"2024-11-01","month":11,"year":2024},{"day":2,"holiday":false,"localDate":"2024-11-02","month":11,"year":2024}]],[[{"day":27,"holiday":false,"localDate":"2024-10-27","month":10,"year":2024},{"day":28,"holiday":false,"localDate":"2024-10-28","month":10,"year":2024},{"day":29,"holiday":false,"localDate":"2024-10-29","month":10,"year":2024},{"day":30,"holiday":false,"localDate":"2024-10-30","month":10,"year":2024},{"day":31,"holiday":false,"localDate":"2024-10-31","month":10,"year":2024},{"day":1,"holiday":false,"localDate":"2024-11-01","month":11,"year":2024},{"day":2,"holiday":false,"localDate":"2024-11-02","month":11,"year":2024}],[{"day":3,"holiday":false,"localDate":"2024-11-03","month":11,"year":2024},{"day":4,"holiday":false,"localDate":"2024-11-04","month":11,"year":2024},{"day":5,"holiday":false,"localDate":"2024-11-05","month":11,"year":2024},{"day":6,"holiday":false,"localDate":"2024-11-06","month":11,"year":2024},{"day":7,"holiday":false,"localDate":"2024-11-07","month":11,"year":2024},{"day":8,"holiday":false,"localDate":"2024-11-08","month":11,"year":2024},{"day":9,"holiday":false,"localDate":"2024-11-09","month":11,"year":2024}],[{"day":10,"holiday":false,"localDate":"2024-11-10","month":11,"year":2024},{"day":11,"holiday":false,"localDate":"2024-11-11","month":11,"year":2024},{"day":12,"holiday":false,"localDate":"2024-11-12","month":11,"year":2024},{"day":13,"holiday":false,"localDate":"2024-11-13","month":11,"year":2024},{"day":14,"holiday":false,"localDate":"2024-11-14","month":11,"year":2024},{"day":15,"holiday":false,"localDate":"2024-11-15","month":11,"year":2024},{"day":16,"holiday":false,"localDate":"2024-11-16","month":11,"year":2024}],[{"day":17,"holiday":false,"localDate":"2024-11-17","month":11,"year":2024},{"day":18,"holiday":false,"localDate":"2024-11-18","month":11,"year":2024},{"day":19,"holiday":false,"localDate":"2024-11-19","month":11,"year":2024},{"day":20,"holiday":false,"localDate":"2024-11-20","month":11,"year":2024},{"day":21,"holiday":false,"localDate":"2024-11-21","month":11,"year":2024},{"day":22,"holiday":false,"localDate":"2024-11-22","month":11,"year":2024},{"day":23,"holiday":false,"localDate":"2024-11-23","month":11,"year":2024}],[{"day":24,"holiday":false,"localDate":"2024-11-24","month":11,"year":2024},{"day":25,"holiday":false,"localDate":"2024-11-25","month":11,"year":2024},{"day":26,"holiday":false,"localDate":"2024-11-26","month":11,"year":2024},{"day":27,"holiday":false,"localDate":"2024-11-27","month":11,"year":2024},{"day":28,"holiday":false,"localDate":"2024-11-28","month":11,"year":2024},{"day":29,"holiday":false,"localDate":"2024-11-29","month":11,"year":2024},{"day":30,"holiday":false,"localDate":"2024-11-30","month":11,"year":2024}]],[[{"day":1,"holiday":false,"localDate":"2024-12-01","month":12,"year":2024},{"day":2,"holiday":false,"localDate":"2024-12-02","month":12,"year":2024},{"day":3,"holiday":false,"localDate":"2024-12-03","month":12,"year":2024},{"day":4,"holiday":false,"localDate":"2024-12-04","month":12,"year":2024},{"day":5,"holiday":false,"localDate":"2024-12-05","month":12,"year":2024},{"day":6,"holiday":false,"localDate":"2024-12-06","month":12,"year":2024},{"day":7,"holiday":false,"localDate":"2024-12-07","month":12,"year":2024}],[{"day":8,"holiday":false,"localDate":"2024-12-08","month":12,"year":2024},{"day":9,"holiday":false,"localDate":"2024-12-09","month":12,"year":2024},{"day":10,"holiday":false,"localDate":"2024-12-10","month":12,"year":2024},{"day":11,"holiday":false,"localDate":"2024-12-11","month":12,"year":2024},{"day":12,"holiday":false,"localDate":"2024-12-12","month":12,"year":2024},{"day":13,"holiday":false,"localDate":"2024-12-13","month":12,"year":2024},{"day":14,"holiday":false,"localDate":"2024-12-14","month":12,"year":2024}],[{"day":15,"holiday":false,"localDate":"2024-12-15","month":12,"year":2024},{"day":16,"holiday":false,"localDate":"2024-12-16","month":12,"year":2024},{"day":17,"holiday":false,"localDate":"2024-12-17","month":12,"year":2024},{"day":18,"holiday":false,"localDate":"2024-12-18","month":12,"year":2024},{"day":19,"holiday":false,"localDate":"2024-12-19","month":12,"year":2024},{"day":20,"holiday":false,"localDate":"2024-12-20","month":12,"year":2024},{"day":21,"holiday":false,"localDate":"2024-12-21","month":12,"year":2024}],[{"day":22,"holiday":false,"localDate":"2024-12-22","month":12,"year":2024},{"day":23,"holiday":false,"localDate":"2024-12-23","month":12,"year":2024},{"day":24,"holiday":false,"localDate":"2024-12-24","month":12,"year":2024},{"day":25,"holiday":false,"localDate":"2024-12-25","month":12,"year":2024},{"day":26,"holiday":false,"localDate":"2024-12-26","month":12,"year":2024},{"day":27,"holiday":false,"localDate":"2024-12-27","month":12,"year":2024},{"day":28,"holiday":false,"localDate":"2024-12-28","month":12,"year":2024}],[{"day":29,"holiday":false,"localDate":"2024-12-29","month":12,"year":2024},{"day":30,"holiday":false,"localDate":"2024-12-30","month":12,"year":2024},{"day":31,"holiday":false,"localDate":"2024-12-31","month":12,"year":2024},{"day":1,"holiday":false,"localDate":"2025-01-01","month":1,"year":2025},{"day":2,"holiday":false,"localDate":"2025-01-02","month":1,"year":2025},{"day":3,"holiday":false,"localDate":"2025-01-03","month":1,"year":2025},{"day":4,"holiday":false,"localDate":"2025-01-04","month":1,"year":2025}]]],
        openCalendar: false
        }
    },
  methods: {
    showCalendar(){
      this.openCalendar = true;
    },
    cancelCalendar(){
      this.openCalendar = false;
    }
}

数据是在服务端组装的

package com.xx;

import com.alibaba.fastjson2.JSONObject;
import lombok.Data;

import java.time.*;
import java.time.temporal.ChronoUnit;
import java.time.temporal.TemporalAdjusters;
import java.time.temporal.WeekFields;
import java.util.*;

public class Demo {
    private static final Map<String,String> holidays;
    static{
        holidays = new HashMap<>();
        holidays.put("2024-01-01","元旦");
        holidays.put("2024-10-01","国庆节");
        holidays.put("2024-10-02","国庆节");
        holidays.put("2024-10-03","国庆节");
    }

    public static void main(String[] args) {
        int year = 2024; // 指定年份
        WeekFields weekFields = WeekFields.of(Locale.getDefault());
        List<List<List<MyDate>>> list = new ArrayList<>();
        //遍历12个月
        for (int i = 1; i <= 12; i++){
            List<List<MyDate>> weekList = new ArrayList<>();
            list.add(weekList);
            //card展示第一天
            LocalDate firstDayOfMonth = LocalDate.of(year, i, 1);
            LocalDate firstDay = firstDayOfMonth.with(weekFields.dayOfWeek(), 1);
            //card展示最后一天
            LocalDate lastDayOfMonth = firstDayOfMonth.with(TemporalAdjusters.lastDayOfMonth());
            LocalDate lastDay = lastDayOfMonth.with(weekFields.dayOfWeek(), 1).plusDays(6);
            //这个月有几周
            long weeksBetween = ChronoUnit.WEEKS.between(firstDay, lastDay);
            int cou = 0;
            //遍历每周
            for (int j = 0; j < weeksBetween+1; j++){
                List<MyDate> week = new ArrayList<>();
                weekList.add(week);
                //遍历每天
                for (int k = 0; k < 7; k++){
                    LocalDate localDate = firstDay.plusDays(cou++);
                    MyDate myDate = new MyDate();
                    myDate.setYear(localDate.getYear());
                    myDate.setMonth(localDate.getMonthValue());
                    myDate.setDay(localDate.getDayOfMonth());
                    myDate.setLocalDate(localDate.toString());
                    myDate.setHoliday(holidays.containsKey(localDate.toString()));//是否是节假日
                    myDate.setHolidayName(holidays.get(localDate.toString()));//什么节日
                    week.add(myDate);
                }
            }
        }
        System.out.println(JSONObject.toJSONString(list));
    }
}

@Data
class MyDate {
    private String localDate;
    private int year;
    private int month;
    private int day;
    private boolean isHoliday;
    private String holidayName;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

在写bug的路上越走越远

谢谢老板,老板发大财

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值