欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

elementui?el-calendar日歷組件使用示例

 更新時(shí)間:2023年12月01日 14:18:27   作者:瑞瑞_  
這篇文章主要為大家介紹了elementui?el-calendar日歷組件使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

需求

需要在日歷基礎(chǔ)上展示每天排班記錄及排班詳情、當(dāng)天是否有異常情況。完成效果:

elementui自帶切換月份按鈕與設(shè)計(jì)圖不符,所以我隱藏了插件自帶的按鈕,自己加了個(gè)左右切換圖標(biāo),代碼如下:

// 隱藏組件自帶切換月份按鈕
::v-deep.el-calendar .el-calendar__button-group{
   display: none;
}

在html中新增
<!-- 日歷兩側(cè)年月切換 -->
<img class="month-cut-img month-cut-left" @click="dateCut(1)" src="../../../../assets/img/scheduling/calendar-month-left.png" />
<img class="month-cut-img month-cut-right" @click="dateCut(2)" src="../../../../assets/img/scheduling/calendar-month-right.png" />
<img class="month-cut-img year-cut-left" @click="dateCut(3)" src="../../../../assets/img/scheduling/calendar-year-left.png" />
<img class="month-cut-img year-cut-right" @click="dateCut(4)" src="../../../../assets/img/scheduling/calendar-year-right.png" />

具體代碼實(shí)現(xiàn)

html

<!-- 日歷兩側(cè)年月切換 -->
<img class="month-cut-img month-cut-left" @click="dateCut(1)" src="../../../../assets/img/scheduling/calendar-month-left.png" />
<img class="month-cut-img month-cut-right" @click="dateCut(2)" src="../../../../assets/img/scheduling/calendar-month-right.png" />
<img class="month-cut-img year-cut-left" @click="dateCut(3)" src="../../../../assets/img/scheduling/calendar-year-left.png" />
<img class="month-cut-img year-cut-right" @click="dateCut(4)" src="../../../../assets/img/scheduling/calendar-year-right.png" />
<!-- 日歷 -->
<el-calendar v-model="calendarVal">
  <template slot="dateCell" slot-scope="{date, data}">
    <div @click="viewDetail(data.day)">
      <div class="date">{{ data.day.slice(8) }}</div>
      <div v-for="item in schedulingData.schedulingHandle">
        <div v-if="item.date == data.day">
          <!-- 是否異常 -->
          <div class="abnormal-state" v-if="item.hasException === true"></div>
          <!-- 排版情況 === memberAmount:根據(jù)是否有值班成員判斷是否排班;isPast:日期是否已過;isToday:是否是今天  -->
          <div class="scheduling-state scheduling-state-notset" v-if="item.memberAmount === 0">
            <img src="../../../../assets/img/scheduling/scheduling-state1.png">
            <span class="f14">未排</span>
          </div>
          <div class="scheduling-state scheduling-state-ordering1" v-if="item.memberAmount > 0 && item.isPast === true && item.isToday === false">
            <img src="../../../../assets/img/scheduling/scheduling-state2.png">
            <span class="f14">已排</span>
          </div>
          <div class="scheduling-state scheduling-state-ordering2" v-if="item.memberAmount > 0 && item.isToday === true">
            <img src="../../../../assets/img/scheduling/scheduling-state3.png">
            <span class="f14">已排</span>
          </div>
          <div class="scheduling-state scheduling-state-ordering3" v-if="item.memberAmount > 0 && item.isPast === false && item.isToday === false">
            <img src="../../../../assets/img/scheduling/scheduling-state4.png">
             <span class="f14">已排</span>
          </div>
          <!-- 當(dāng)日排班情況彈窗 -->
          <div class="today-scheduling-detail" v-if="item.showTodayScheduling">
            <div class="today-scheduling-title">當(dāng)日排班</div>
            <div class="today-scheduling-center">
              <div class="today-scheduling-item" v-for="item1 in item.todayDetail">
                <div class="name1">{{ item1.shiftName }}</div>
                <div class="name2">{{ item1.crewName }}</div>
              </div>
            </div>
            <div class="today-scheduling-footer">
              <div class="edit"><span class="el-icon-edit"></span>編輯</div>
              <div class="view"><span class="el-icon-view"></span>查看</div>
            </div>
          </div>
        </div>
      </div>
    </div>
  </template>
</el-calendar>
<div class="back-to-today" @click="dateCut(5)">回到今天</div>

js 

dateCut(type) {
  // type:1 月份左側(cè)按鈕,2 月份右側(cè)按鈕,3 年份左側(cè)按鈕,4 年份右側(cè)按鈕,5 回到今天
  if (type === 1) {
    this.calendarVal = new Date(this.calendarVal).getMonth() > 0 ?
      new Date(this.calendarVal).getFullYear() + '-' + new Date(this.calendarVal).getMonth() + '-01' :
      new Date(this.calendarVal).getFullYear() - 1 + '-12' + '-01'
  } else if (type === 2) {
    this.calendarVal = new Date(this.calendarVal).getMonth() < 11 ?
      new Date(this.calendarVal).getFullYear() + '-' + (Number(new Date(this.calendarVal).getMonth()) + 2) + '-01' :
      new Date(this.calendarVal).getFullYear() + 1 + '-01' + '-01'
  } else if (type === 3) {
    this.calendarVal = new Date(this.calendarVal).getFullYear() - 1 + '-' + (Number(new Date(this.calendarVal).getMonth()) + 1) + '-01'
  } else if (type === 4) {
     this.calendarVal = new Date(this.calendarVal).getFullYear() + 1 + '-' + (Number(new Date(this.calendarVal).getMonth()) + 1) + '-01'
  } else if (type === 5) {
     this.calendarVal = this.getDate(new Date()).fullDate
  }
  this.getData() // 調(diào)接口數(shù)據(jù)
},

css代碼

// 日歷組件樣式修改
  .is-selected {
    color: #1989FA;
  }
  ::v-deep.el-calendar{
    height: calc(100% - 35px);
  }
  ::v-deep.el-calendar .el-calendar__body{
    padding-bottom: 16px;
    height: calc(100% - 80px);
  }
  ::v-deep.el-calendar .el-calendar-table{
    height: 100%;
  }
  .el-backtop, ::v-deep.el-calendar .el-calendar-table td.is-today .date{
    //background: #5E97F9;
    //box-shadow: 0px 4px 7px 0px rgba(113,208,255,0.5);
    //color: #fff;
    background: #DCE9FF;
    color: rgba(0,0,0,0.45);
  }
  .el-backtop, ::v-deep.el-calendar .el-calendar-table .date:hover{
    background: #DCE9FF;
    color: rgba(0,0,0,0.45);
  }
  ::v-deep.el-calendar .el-calendar-table .el-calendar-day:hover{
    background: none;
  }
  ::v-deep.el-calendar .el-calendar-table td.is-selected{
    background: none;
  }
  ::v-deep.el-calendar .el-calendar-table td.is-selected .date{
    background: #5E97F9;
    box-shadow: 0px 4px 7px 0px rgba(113,208,255,0.5);
    color: #fff;
  }
  ::v-deep.el-calendar .el-calendar__button-group{
    display: none;
  }
  ::v-deep.el-calendar .el-calendar__title{
    margin: 0 auto;
  }
  ::v-deep.el-calendar .el-calendar-table .el-calendar-day{
    position: relative;
  }

日歷組件就完成了,有任何問題歡迎大家留言!

以上就是elementui el-calendar日歷組件使用示例的詳細(xì)內(nèi)容,更多關(guān)于elementui el-calendar日歷組件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue-element-admin開發(fā)教程(v4.0.0之前)

    vue-element-admin開發(fā)教程(v4.0.0之前)

    本文主要介紹了vue-element-admin開發(fā)教程(v4.0.0之前),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • Vue打包后靜態(tài)資源圖片失效徹底解決的終極指南

    Vue打包后靜態(tài)資源圖片失效徹底解決的終極指南

    文章詳細(xì)分析了Vue項(xiàng)目中靜態(tài)資源路徑失效的問題,包括開發(fā)、構(gòu)建、部署等階段的常見原因,并提供了多種解決方案,旨在幫助開發(fā)者系統(tǒng)性地解決靜態(tài)資源路徑問題,構(gòu)建穩(wěn)定可靠的前端應(yīng)用,需要的朋友可以參考下
    2025-03-03
  • vue項(xiàng)目debugger調(diào)試看不到源碼的問題及解決

    vue項(xiàng)目debugger調(diào)試看不到源碼的問題及解決

    這篇文章主要介紹了vue項(xiàng)目debugger調(diào)試看不到源碼的問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Vue項(xiàng)目實(shí)現(xiàn)token無感刷新的示例代碼

    Vue項(xiàng)目實(shí)現(xiàn)token無感刷新的示例代碼

    最近在使用系統(tǒng)的過程中,業(yè)務(wù)人員反饋剛登錄一會(huì)就提示token過期需要重新登錄,所以本文為大家分享一個(gè)無感刷新的實(shí)現(xiàn)代碼,需要的可以參考下
    2023-07-07
  • 從零開始封裝自己的自定義Vue組件

    從零開始封裝自己的自定義Vue組件

    如何封裝自己的Vue組件,如何把自己的Vue代碼封裝成公共組件,今天為大家簡(jiǎn)單介紹一下如何封裝自己的Vue組件
    2018-10-10
  • 去除Element-Plus下拉菜單邊框的實(shí)現(xiàn)步驟

    去除Element-Plus下拉菜單邊框的實(shí)現(xiàn)步驟

    Element-Plus 是 Element UI 的 Vue 3 版本,它提供了一套完整的組件庫,在使用 Element-Plus 進(jìn)行開發(fā)時(shí),我們可能會(huì)遇到需要自定義組件樣式的情況,本文將介紹如何使用 CSS 來去除 Element-Plus 下拉框的邊框,需要的朋友可以參考下
    2024-03-03
  • vue+tsc+noEmit導(dǎo)致打包報(bào)TS類型錯(cuò)誤問題及解決方法

    vue+tsc+noEmit導(dǎo)致打包報(bào)TS類型錯(cuò)誤問題及解決方法

    當(dāng)我們新建vue3項(xiàng)目,package.json文件會(huì)自動(dòng)給我添加一些配置選項(xiàng),這寫選項(xiàng)基本沒有問題,但是在實(shí)際操作過程中,當(dāng)項(xiàng)目越來越復(fù)雜就會(huì)出現(xiàn)問題,本文給大家分享vue+tsc+noEmit導(dǎo)致打包報(bào)TS類型錯(cuò)誤問題及解決方法,感興趣的朋友一起看看吧
    2023-10-10
  • element el-table實(shí)現(xiàn)多級(jí)表頭的代碼

    element el-table實(shí)現(xiàn)多級(jí)表頭的代碼

    多級(jí)表頭的作用與優(yōu)勢(shì),多級(jí)表頭能夠清晰地展示數(shù)據(jù)的層次結(jié)構(gòu),幫助我們更好地理解數(shù)據(jù)之間的關(guān)系,下面通過本文給大家介紹element el-table實(shí)現(xiàn)多級(jí)表頭的代碼,感興趣的朋友跟隨小編一起看看吧
    2024-04-04
  • vue-awesome-swiper 基于vue實(shí)現(xiàn)h5滑動(dòng)翻頁效果【推薦】

    vue-awesome-swiper 基于vue實(shí)現(xiàn)h5滑動(dòng)翻頁效果【推薦】

    說到h5的翻頁,很定第一時(shí)間想到的是swiper。但是我當(dāng)時(shí)想到的卻是,vue里邊怎么用swiper。這篇文章主要介紹了vue-awesome-swiper - 基于vue實(shí)現(xiàn)h5滑動(dòng)翻頁效果 ,需要的朋友可以參考下
    2018-11-11
  • Vue中關(guān)于異步請(qǐng)求數(shù)據(jù)未更新的解決

    Vue中關(guān)于異步請(qǐng)求數(shù)據(jù)未更新的解決

    本文將探討Vue中異步請(qǐng)求數(shù)據(jù)未更新的常見原因,并提供解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-03-03

最新評(píng)論