關(guān)于elementUI里日期選擇器禁用時間的一些小技巧

DatePicker日期選擇器算是日常開發(fā)中用得比較多的插件之一了,特別是做一些后臺管理系統(tǒng)董虱,選擇時間店煞、日期也是特別的方便,相比于原生的input中的date诵原,elementUI中的日期選擇器顯得更加的好看英妓,暴露出的方法也更加的使用方便挽放。下面我們一起來看一下它的其中一個方法,禁用日期disabledDate蔓纠。

DatePicker 日期選擇器

其官網(wǎng)地址是:elementUI DatePicker 日期選擇器


PS:由于工作需要辑畦,并未使用elementUI較新的版本,而是使用了停止更新的1.4版本腿倚。


我們知道纯出,常用的禁止日期方法已經(jīng)在第一個demo中展示,通過配置picker-options中的disabledDate屬性敷燎,而disabledDate通常是一個函數(shù)暂筝,其有一個默認的參數(shù),表示可供選擇的時間硬贯,還有一個為布爾類型的返回值焕襟,返回true表示該時間可用,反之為不可用澄成。
(PS:文檔上并未明確指出該參數(shù)代表的是什么胧洒。其使用的參數(shù)名為time,本人通過log調(diào)試墨状,感覺應(yīng)該是表示可供選擇的時間)卫漫。
官網(wǎng)給出的demo更多的是一些固定的時間,比如一天前肾砂,一周前等等列赎,使用方法也十分簡單。
只需要

//script部分

data() {
      return {
        value: '',
        pickerOptions: {
          disabledDate(time) {
            return time.getTime() < Date.now() - 8.64e7;
          }
        }
}
//template部分

 <el-date-picker
      v-model="value"
      type="date"
      placeholder="選擇日期"
      :picker-options="pickerOptions">
 </el-date-picker>

如上文所述镐确,一個picker-options對象中包吝,包含了一個keydisabledDatevalue為一個返回值為布爾值的函數(shù)源葫。其中诗越,函數(shù)有一個默認參數(shù)為time

為什么要多次強調(diào)這里有一個默認參數(shù)呢息堂,因為坑就在這里....想象一下這樣的場景
需要禁用的時間并非是基于今天的某個時間嚷狞,這個時間是不固定的,并非是Date.now()荣堰。這里可以這樣處理床未,把時間變量放在data中,具體代碼如下:

//script部分

data() {
      return {
      value: '',
      date: '',
      pickerOptions: {} 
}

created () {
     this.pickerOptions = {
           disabledDate(time) {
              return time.getTime() < new Date(this.date).getTime();
           }
     }
}
//template部分

 <el-date-picker
      v-model="value"
      type="date"
      placeholder="選擇日期"
      :picker-options="pickerOptions">
 </el-date-picker>

當(dāng)然這是在知道時間變量this.date的情況下可以這樣做振坚,如果這個時間變量并不是那么好找的時候呢薇搁?
我就遇到這樣一個場景,需要動態(tài)渲染一些時間表單渡八,但是具體表單的數(shù)量啃洋,名稱都不知道传货,是后端傳過來的數(shù)據(jù),這個時候就不能預(yù)先找到'this.date'了裂允,因為連this.date本身损离,也是根據(jù)后端傳來的數(shù)據(jù)生成的。
這個時候绝编,就需要傳參了僻澎,把我需要限制的時間傳遞到disabledDate這個函數(shù)中。
我們知道十饥,這個函數(shù)有默認的參數(shù)time窟勃,如果正常的傳參,會導(dǎo)致time丟失逗堵,那么應(yīng)該怎么處理呢秉氧,請看下面的代碼:

//script部分

data() {
      return {
      value: '',
      pickerOptions: {} 
}

created () {
     this.pickerOptions = function (date)  {
           return disabledDate(time) {
              return time.getTime() < new Date(date).getTime();
           }
     }
}
//template部分

 <el-date-picker
      v-model="value"
      type="date"
      placeholder="選擇日期"
      :picker-options="pickerOptions(DateParam)">
 </el-date-picker>

其實可以看出,就是做了一個閉包蜒秤,將參數(shù)傳過去的同時不破壞disabledDate本身的傳參汁咏,這樣無論是參數(shù),還是time都拿到了作媚。完美解決時間禁用問題攘滩。


寫在后面

當(dāng)然,這種閉包的思路并不是對于所有的elementUI控件有默認值的方法都是生效的纸泡,之前有試過checkBox控件的change方法漂问,貌似是行不通的。在網(wǎng)上查詢后發(fā)現(xiàn)是使用$event去表示默認傳參女揭,具體代碼如下:

<el-checkbox @change="handleChange($event, someParam)"></el-checkbox>

具體原理并未深究蚤假,有時間的話可以去研究一下...現(xiàn)在是能解決問題就OK了.

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市吧兔,隨后出現(xiàn)的幾起案子磷仰,更是在濱河造成了極大的恐慌,老刑警劉巖境蔼,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件芒划,死亡現(xiàn)場離奇詭異,居然都是意外死亡欧穴,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進店門泵殴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來涮帘,“玉大人,你說我怎么就攤上這事笑诅〉饔В” “怎么了疮鲫?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長弦叶。 經(jīng)常有香客問我俊犯,道長,這世上最難降的妖魔是什么伤哺? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任燕侠,我火速辦了婚禮,結(jié)果婚禮上立莉,老公的妹妹穿的比我還像新娘绢彤。我一直安慰自己,他們只是感情好蜓耻,可當(dāng)我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布茫舶。 她就那樣靜靜地躺著,像睡著了一般刹淌。 火紅的嫁衣襯著肌膚如雪饶氏。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天有勾,我揣著相機與錄音疹启,去河邊找鬼。 笑死柠衅,一個胖子當(dāng)著我的面吹牛皮仁,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播菲宴,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼贷祈,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了喝峦?” 一聲冷哼從身側(cè)響起势誊,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎谣蠢,沒想到半個月后粟耻,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡眉踱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年挤忙,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片谈喳。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡册烈,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出婿禽,到底是詐尸還是另有隱情赏僧,我是刑警寧澤大猛,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站淀零,受9級特大地震影響挽绩,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜驾中,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一唉堪、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧哀卫,春花似錦巨坊、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至共啃,卻和暖如春占调,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背移剪。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工究珊, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人纵苛。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓剿涮,卻偏偏與公主長得像,于是被迫代替她去往敵國和親攻人。 傳聞我的和親對象是個殘疾皇子取试,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容