My code looks like this:
function loadData() {
$.ajax({
url: "",
async: true,
method: 'post',
dataType: "json",
data: {
start: $('input[name=start]').val(),
stop: $('input[name=end]').val(),
week: $('#weekpicker').val(),
range:$('select[name=date_control]').val(),
type: 'loaddata'
},
beforeSend: function(xhr, opts) {
if (!$('input[name=start]').val() && !$('input[name=end]').val()) {
bootbox.alert('Select date first!');
xhr.abort();
return false;
}
},
success: function(dane) {
ustawienia = dane.ustawienia;
// some code here
},
error: function(dane) {
$('button[name=pokaz]').removeAttr('disabled');
bootbox.alert(dane.responseText);
}
});
}
On FF, Chrome and IE>8 everything works fine, problem is with IE8.
instead perform the success' function in IE displays an error:
Line 337 in jQuery is:
globalEval: function( data ) {
if ( data && jQuery.trim( data ) ) {
// We use execScript on Internet Explorer
// We use an anonymous function so that context is window
// rather than jQuery in Firefox
( window.execScript || function( data ) {
window[ "eval" ].call( window, data );
} )( data );
}
},
so I've remove jQuery.trim( data )
and next I have this error:
// args is for internal usage only
each: function( obj, callback, args ) {
var value,
i = 0,
length = obj.length, //here is line 357!
isArray = isArraylike( obj );
if ( args ) {
if ( isArray ) {
for ( ; i < length; i++ ) {
value = callback.apply( obj[ i ], args );
if ( value === false ) {
break;
}
}
} else {
for ( i in obj ) {
value = callback.apply( obj[ i ], args );
if ( value === false ) {
break;
}
}
}
// A special, fast, case for the most common use of each
} else {
if ( isArray ) {
for ( ; i < length; i++ ) {
value = callback.call( obj[ i ], i, obj[ i ] );
if ( value === false ) {
break;
}
}
} else {
for ( i in obj ) {
value = callback.call( obj[ i ], i, obj[ i ] );
if ( value === false ) {
break;
}
}
}
}
return obj;
},
What I can do, to make it works?