怎么设置成多选?

发布于 2020-11-20 11:18
共1个回答
AD
游客AdtNgf

多选? 是指日期区间吗?

只需要加上is-range即可:

<v-date-picker value="range" is-range />



data() { return { range: { start: new Date(2020, 0, 1), end: new Date(2020, 0, 5) } } }

image.png

如果不是这样,那就是随意选择日期并让其呈选中状态。 你可以通过attributes选项和inputEvents来实现。 image.png

<v-calendar :attributes="attributes" @dayclick="onDayClick" />

export default {
  data() {
    return {
      days: [],
    };
  },
  computed: {
    dates() {
      return this.days.map(day => day.date);
    },
    attributes() {
      return this.dates.map(date => ({
        highlight: true,
        dates: date,
      }));
    },
  },
  methods: {
    onDayClick(day) {
      const idx = this.days.findIndex(d => d.id === day.id);
      if (idx >= 0) {
        this.days.splice(idx, 1);
      } else {
        this.days.push({
          id: day.id,
          date: day.date,
        });
      }
    },
  },
};

还可以通过slot插槽来实现:

image.png


<template> <div class="bg-white p-2 w-full border rounded"> <v-date-picker v-model="selected.date"> <template #default="{ inputValue, togglePopover, hidePopover }"> <div class="flex flex-wrap"> <button v-for="(date, i) in dates" :key="date.date.getTime()" class="flex items-center bg-indigo-100 hover:bg-indigo-200 text-sm text-indigo-600 font-semibold h-8 px-2 m-1 rounded-lg border-2 border-transparent focus:border-indigo-600 focus:outline-none" @click.stop="dateSelected($event, date, togglePopover)" ref="button" > {{ date.date.toLocaleDateString() }} <svg class="w-4 h-4 text-gray-600 hover:text-indigo-600 ml-1 -mr-1" viewBox="0 0 24 24" stroke="currentColor" stroke-width="2" @click.stop="removeDate(date, hidePopover)" > <path d="M6 18L18 6M6 6l12 12"></path> </svg> </button> </div> </template> </v-date-picker> <button class="text-sm text-indigo-600 font-semibold hover:text-indigo-500 px-2 h-8 focus:outline-none" @click.stop="addDate" > + Add Date </button> </div> </template>
export default {
  data() {
    return {
      dates: [
        {
          date: new Date(),
        },
      ],
      selected: {},
    };
  },
  methods: {
    addDate() {
      this.dates.push({
        date: new Date(),
      });
      this.$nextTick(() => {
        const btn = this.$refs.button[this.$refs.button.length - 1];
        btn.click();
      });
    },
    removeDate(date, hide) {
      this.dates = this.dates.filter((d) => d !== date);
      hide();
    },
    dateSelected(e, date, toggle) {
      this.selected = date;
      toggle({ ref: e.target });
    },
  },
};

回答问题
903 阅读
1 回答
5