javascript — использование ответа на обещания в функции календаря (которая требует данных от вызова ajax)

Аякс пообещал:

var promise = new Promise(function(resolve, reject) {
jQuery.ajax({
url:'<?php echo site_url();?>/MyController/ajax_cal',
type:'POST',
dataType: "JSON",
success:function(results) {
resolve(results);
//reject(Error(request.statusText)); // status is not 200 O K, so reject
}
});
});

Успокойся от обещания

promise.then(function(data) {
alert(data); // this is working fine BUT i want to use this in calendar function

}, function(error) {
console.log('Promise rejected.');
console.log(error.message);
});

Calander Javascript код:

<!-- Calander Module starts-->
var calendar = $('#calendar').calendar({

console.log(data); /// want to use the data from ajax call on promises
events_source: data  , // here
view: 'month',
tmpl_path: '<?php echo base_url();?>asserts/bootstrap_calender/tmpls/',
tmpl_cache: false,
day: '2017-02-14',
onAfterEventsLoad: function(events) {
if(!events) {
return;
}
var list = $('#eventlist');
list.html('');

$.each(events, function(key, val) {
$(document.createElement('li'))
.html('<a href="' + val.url + '">' + val.title + '</a>')
.appendTo(list);
});
},
onAfterViewLoad: function(view) {
$('.page-header h3').text(this.getTitle());
$('.btn-group button').removeClass('active');
$('button[data-calendar-view="' + view + '"]').addClass('active');
},
classes: {
months: {
general: 'label'
}
}
});
(function($) {
$('.btn-group button[data-calendar-nav]').each(function() {
var $this = $(this);
$this.click(function() {
calendar.navigate($this.data('calendar-nav'));
});
});

$('.btn-group button[data-calendar-view]').each(function() {
var $this = $(this);
$this.click(function() {
calendar.view($this.data('calendar-view'));
});
});

$('#first_day').change(function(){
var value = $(this).val();
value = value.length ? parseInt(value) : null;
calendar.setOptions({first_day: value});
calendar.view();
});

$('#language').change(function(){
calendar.setLanguage($(this).val());
calendar.view();
});

$('#events-in-modal').change(function(){
var val = $(this).is(':checked') ? $(this).val() : null;
calendar.setOptions({modal: val});
});
$('#format-12-hours').change(function(){
var val = $(this).is(':checked') ? true : false;
calendar.setOptions({format12: val});
calendar.view();
});
$('#show_wbn').change(function(){
var val = $(this).is(':checked') ? true : false;
calendar.setOptions({display_week_numbers: val});
calendar.view();
});
$('#show_wb').change(function(){
var val = $(this).is(':checked') ? true : false;
calendar.setOptions({weekbox: val});
calendar.view();
});
$('#events-modal .modal-header, #events-modal .modal-footer').click(function(e){
//e.preventDefault();
//e.stopPropagation();
});
}(jQuery));
<!-- Calander Module ends-->

Я хочу, чтобы получить динамические данные (формат JSON) в «поле календаря events_source». Я использовал AJAX-вызов, но я узнал, что переменная недоступна вне AJAX-вызова. Я использую обещания, чем успешно оповещаю переменную вне вызова ajax. Но я все еще не могу получить к ней доступ в «поле календаря events_source». я не знаю, что не так и как я могу это использовать.

1

Решение

Один из способов решить эту проблему — создать элемент календаря после того, как у вас есть данные (в блоке «затем»). Я, вероятно, сделал бы это так, чтобы я построил пользовательский интерфейс, затем вызвал выборку и в функции then () я бы вызвал onAfterEventsLoad с полученными событиями, так как, кажется, построить календарь.

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]