This code works in FF and chrome. In IE 8 or 9 I get a 500 error saying a not
On IE if you return data like json when you upload a file you can get this data(json) like this:
done: function (e, datos)
{
try
{
//This in FF, Chrome, Safari
data=eval(JSON.parse(datos.result));
}catch (er)
{
//This in IE
data=eval(JSON.parse(datos.result[0].documentElement.innerText));
}
If by jQuery fileupload you mean using http://blueimp.github.com/jQuery-File-Upload/ then it clearly says in the browser support section that IE 10+ is required for every functionality they implemented.
https://github.com/blueimp/jQuery-File-Upload/wiki/Browser-support
If you meant another plugin, just disregard my comment.
Just set the content-type to text/html and send it as JSON.
This should work for all browsers.
I was able to get it working by including jquery.iframe-transport.js and then I had to remove my knockout "with" data-bind from the div to get it to work in IE8 because it worked in IE9. (I had a with binding above my posted code) Thanks for all the suggestions.
As this function is working fine in FF, there is only one possibility that the variables you are passing here are undefined just for IE.
Check each variables values in IE console.
Hint: IE is strict about types and everything.
For example:
parseInt(Number);
FF and Chrome assumes it as decimal value whereas IE assumes it as octal number.
So, giving parseInt(Number,10)
is recommended.
And even regarding dates, if you provide
var currentDate = new Date("March 18, 2013 11:13:00")
Works good in Chrome and FF, but shows undefined
or invalid Date
in IE.
You can find more about the recommended notation of the date here
So, in the above examples I am just trying to say you that you may have forgotten to declare type, or correct notation.
Though, this is not the answer you were looking for, I hope this information will help you.
Update: As the error is 500 error
, then the problem could be more possibly in rootPath
variable's value.
$("#txt1").fileupload({
replaceFileInput: false,
dataType: "json",
datatype:"json",
url: "<%=Page.ResolveUrl("~/WebService/AddAttachment.ashx")%>",
done: function (e, data) {
$.each(data.result, function (index, value) {
//You get the response data in here from your web service
})
$("#txt1").val("");
}`enter code here`
});
This is tested and working fine in both IE8 and IE9 + above. Please make sure to use the correct dataType:"json" (or datatype:"json") and also make sure your response of web service method is correct. Thanks