J'ai un petit script/javascript, Babel, qui fonctionne très bien dans Chrome et les navigateurs Firefox, mais il échoue dans Internet Explorer 11.
J'espère que quelqu'un peut m'aider.
Voici ma fonction:
getDaysWithEvents() {
// Get all the days in this months calendar view
// Sibling Months included
const days = this.getCalendarDays();
// Set Range Limits on calendar
this.calendar.setStartDate(days[0]);
this.calendar.setEndDate(days[days.length - 1]);
// Iterate over each of the supplied events
this.props.events.forEach((eventItem) => {
const eventStart = this.getCalendarDayObject(eventItem.start);
const eventEnd = this.getCalendarDayObject(eventItem.end);
const eventMeta = this.getEventMeta(days, eventStart, eventEnd);
if (eventMeta.isVisibleInView) {
const eventLength = eventMeta.visibleEventLength;
const eventSlotIndex = days[eventMeta.firstVisibleDayIndex].eventSlots.indexOf(false);
let dayIndex = 0;
// For each day in the event
while (dayIndex < eventLength) {
// Clone the event object so we acn add day specfic data
const eventData = Object.assign({}, eventItem);
if (dayIndex === 0) {
// Flag first day of event
eventData.isFirstDay = true;
}
if (dayIndex === eventLength - 1) {
// Flag last day of event
eventData.isLastDay = true;
}
if (!eventData.isFirstDay || !eventData.isLastDay) {
// Flag between day of event
eventData.isBetweenDay = true;
}
// Apply Event Data to the correct slot for that day
days[eventMeta.firstVisibleDayIndex + dayIndex].eventSlots[eventSlotIndex] = eventData;
// Move to next day of event
dayIndex++;
}
}
});
return days;
}
Erreur:
SCRIPT438: The object does not support the property or method 'assign'
Cette ligne contient Erreur: var eventData = Object.assign({}, eventItem);
Puis-je réécrire cette ligne ..?
Comment le réparer ?
IE ne prend pas en charge Object.assign ()
Utilisez polyfil
if (typeof Object.assign != 'function') {
Object.assign = function(target, varArgs) { // .length of function is 2
'use strict';
if (target == null) { // TypeError if undefined or null
throw new TypeError('Cannot convert undefined or null to object');
}
var to = Object(target);
for (var index = 1; index < arguments.length; index++) {
var nextSource = arguments[index];
if (nextSource != null) { // Skip over if undefined or null
for (var nextKey in nextSource) {
// Avoid bugs when hasOwnProperty is shadowed
if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) {
to[nextKey] = nextSource[nextKey];
}
}
}
}
return to;
};
}
Si vous utilisez babel
npm install --save-dev babel-plugin-transform-object-assign
en utilisant .babelrc
{
"plugins": ["transform-object-assign"]
}
vous pouvez trouver d'autres méthodes ici
Si vous utilisez jquery , vous pouvez essayer jQuery.extend (target [ object1] [ objectN]) . Votre code:
const eventData = $.extend({}, eventItem);
La réponse de Dinesh undefined est dépassée en ce qui concerne la partie babel
. C'est ainsi que cela se fait aujourd'hui.
Sur la ligne de commande:
npm install --save-dev @babel/plugin-transform-object-assign
Dans votre .babelrc
:
{ "plugins": ["@babel/plugin-transform-object-assign"] }