Destruya el calendario completo en las pestañas de arranque, haga clic antes de que se inicialice el nuevo calendario

Santosh

Tengo dos pestañas de bootstrap. Fullcalendar está dentro de la segunda pestaña que está oculta por defecto. Entonces uso el evento onclick para activar la calendar_view_sessionfunción. Pero cada vez que visito esa pestaña, el nuevo calendario se agrega en las mismas pestañas. En realidad, está duplicando el calendario.

        calendar_view_session: function(){
        var calendarEl = document.getElementById('calendar');

        var calendar = new FullCalendar.Calendar(calendarEl, {
      plugins: [ 'dayGrid', 'timeGrid', 'list', 'interaction' , 'momentTimezone' ],
      header: {
        left: 'prev,next today',
        center: 'title',
        right: 'dayGridMonth,timeGridWeek,timeGridDay,listWeek'
      },
      defaultDate: '2019-04-12',
      navLinks: true, // can click day/week names to navigate views
      editable: false,
      eventLimit: true, // allow "more" link when too many events
      events:  function(info, successCallback,failureCallback) {
            console.log(info);

            var date1 = new Date(info.start.valueOf());
            var date2 = new Date(info.end.valueOf());

            var callData = {
                from_date:moment.tz(date1, timeZone).format('YYYY-MM-DD'),
                to_date: moment.tz(date2, timeZone).format('YYYY-MM-DD')
            }
            sessionCalendar = [];
            console.log(callData);
            $.ajax({
                  url:app.createApiPath(apiController_data,apiAction_data),
                  method:"POST",
                  dataType: "json",
                  data: {
                        callData: JSON.parse(JSON.stringify(callData)),
                        api_version: 1,
                        deviceType: 'web'
                    },
                  success: function(responseData){
                    console.log({responseData})
             successCallback(app.calendarParse(responseData.data.results));

                }
            })

          },
          //sessionCalendar
    });

    calendar.render();

},

Mi código HTML

      <div>

    <!-- Nav tabs -->
    <ul class="nav nav-tabs" role="tablist">
      <li role="presentation" class="active"><a href="#list_view_session" aria-controls="list_view_session" role="tab" data-toggle="tab">List View</a></li>
      <li role="presentation"><a href="#calendar_view_session" id="calendar_view_session_id" onclick="app.calendar_view_session()" aria-controls="calendar_view_session" role="tab" data-toggle="tab">Calendar View</a></li>
    </ul>

    <!-- Tab panes -->
    <div class="tab-content">
      <div role="tabpanel" class="tab-pane active" id="list_view_session">


        <div class="session_list">
          <div class="loaderapi hide">
            <i class="fa fa-spinner fa-spin fa-4x" aria-hidden="true"></i>
          </div>
        </div>

      </div>
      <div role="tabpanel" class="tab-pane" id="calendar_view_session">
        <div id='calendar'></div>
      </div>
    </div>

  </div>

Esta es mi función. Sin embargo, $("#calendar").destroy()primero uso la función para destruir el calendario. Muestra error diciendo

sessions.js:253 Uncaught TypeError: $(...).destroy is not a function

Utilizo esta función de destrucción después

var calendarEl = document.getElementById('calendar'); línea.

Wendigo

Debería ejecutar el método de destrucción en calendarbastante y luego en el elemento en el DOM.

Intente usar window.calendar.destroy()en su lugar.

Eche un vistazo a los documentos aquí: https://fullcalendar.io/docs/destroy

Este artículo se recopila de Internet, indique la fuente cuando se vuelva a imprimir.

En caso de infracción, por favor [email protected] Eliminar

Editado en
0

Déjame decir algunas palabras

0Comentarios
Iniciar sesiónRevisión de participación posterior

Artículos relacionados