Как добавить функцию удаления к кнопке удаления события в FullCalendarV4 и Vue.js

Я создаю интерактивный календарь с помощью FullCalendarV4 и Vue.js. Я успешно использовал функцию обратного вызова eventRender, чтобы добавить кнопку удаления к каждому динамически созданному событию. Кнопка удаления по-прежнему нуждается в функциональности. Чтобы включить удаление событий, я попытался использовать метод .setAttribute, чтобы добавить атрибут onclick к кнопке, чтобы вызвать функцию «удалить», нацеленную на отдельные события «btn.setAttribute («onclick», 'remove (info)') ; Затем я попытался использовать метод .removeChild внутри функции удаления, чтобы включить удаление, но безрезультатно. Любые рекомендации о том, как добавить функциональность к динамически созданной кнопке удаления? Мой код приведен ниже. Спасибо!

<template>
  <div class='demo-app'>
    <FullCalendar
      class='demo-app-calendar'
      ref="fullCalendar"
      defaultView="dayGridMonth"
      :header="{
        left: 'prev,next today',
        center: 'title',
        right: 'dayGridMonth,timeGridWeek,timeGridDay,listWeek'
      }"
      :plugins="calendarPlugins"
      :weekends="calendarWeekends"
      :events="calendarEvents"
      @dateClick="handleDateClick"
      @eventRender="eventRender"
      @eventClick="remove"
      />
  </div>
</template>

<script>
import FullCalendar from '@fullcalendar/vue'
import dayGridPlugin from '@fullcalendar/daygrid'
import timeGridPlugin from '@fullcalendar/timegrid'
import interactionPlugin from '@fullcalendar/interaction'

export default {
  components: {
    FullCalendar // make the <FullCalendar> tag available
  },
  data: function() {
    return {
      calendarPlugins: [ // plugins must be defined in the JS
        dayGridPlugin,
        timeGridPlugin,
        interactionPlugin // needed for dateClick
      ],
      calendarWeekends: true,
      calendarEvents: []
    }
  },
  methods: {
    handleDateClick(arg) {
    var newTitle = prompt(arg.dateStr);
      if (newTitle != null) {
        this.calendarEvents.push({
          title: newTitle,
          start: arg.date,
          allDay: arg.allDay
        })
      }
    },
    eventRender(info) {
      var btn = document.createElement("button");
      btn.appendChild(document.createTextNode("x"));
      btn.setAttribute("onclick", 'remove(info)');
      info.el.appendChild(btn);
    },
    remove(info) {
      var task = this.event.currentTarget.parentNode;
      info.el.removeChild(task);
    }
  }
}
</script>

<style lang='scss'>
@import '~@fullcalendar/core/main.css';
@import '~@fullcalendar/daygrid/main.css';
@import '~@fullcalendar/timegrid/main.css';

.demo-app {
  font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  font-size: 14px;
}

.demo-app-top {
  margin: 0 0 3em;
}

.demo-app-calendar {
  margin: 0 auto;
  max-width: 900px;
}

</style>


person JS_is_awesome18    schedule 20.07.2019    source источник
comment
@ittis, спасибо за вашу помощь с тем, как удалить события FullCalendar-4 в Vue.js. Сейчас я пытаюсь добавить функциональность к кнопке удаления. Не могли бы вы взглянуть на этот вопрос, когда у вас будет минутка? Спасибо!   -  person JS_is_awesome18    schedule 20.07.2019


Ответы (1)


Можешь попробовать изменить

  btn.setAttribute("onclick", 'remove(info)');

to

btn.addEventListener('click', () => {
    info.el.remove()
})
person ittus    schedule 20.07.2019
comment
@ittis, спасибо за ответ. Я использовал указанный вами метод addEventListener, но this.remove(info) вернул ошибку. Вместо этого я использовал info.el.remove() внутри метода addEventListener, и это, похоже, сработало, в консоли не было никаких ошибок. Это нормально для использования? - person JS_is_awesome18; 20.07.2019