Reputation: 133
I am using JSON.parse to turn a JSON string into a JSON object. It works in Google Chrome, Firefox, Opera, and Safari but not in IE9. Everytime I use JSON.parse Internet Explorer throws a "SCRIPT1014: Invalid character" error. I have included json2.js into the script since JSON.parse isn't supported in IE8 but to no avail does it still work. How can I make this work?
function run() {
$("#testing").ajaxSubmit({
success: function (data) {
console.log(data);
var parsedjson = JSON.parse(data);
var truejson = parsedjson[0];
}
});
}
LOG: <pre>[{"group":null,"name":"lion.jpg","type":"image/png","size":5269,"progress":"1.0","url":"/Upload/UploadHandler.ashx?f=lion.jpg","thumbnail_url":"","delete_url":"/Upload/UploadHandler.ashx?f=lion.jpg","delete_type":"DELETE","error":null}]</pre>
Upvotes: 1
Views: 3803
Reputation: 1
jQuery.browser This property was removed in jQuery 1.9 and is available only through the jQuery.migrate plugin. Please try to use feature detection instead.
see:http://api.jquery.com/jquery.browser/
Upvotes: 0
Reputation: 133
The answer is to remove the "pre" tags surrounding the returned json string as Internet Explorer throws these tags on in order to preserve the structure of the text. The Form Plugin does work with Internet Explorer but only for same domain cases. CORS unfortunately is not supported by IE9. Solved the problem by doing this....
function imageUploader() {
$("#testing").ajaxSubmit({
success: function (data) {
if (jQuery.browser.msie == true) {
var newdata = data.replace('<pre>', '');
var newdata2 = newdata.replace('</pre>', '');
var parsedjson = JSON.parse(newdata2);
var truejson = parsedjson[0];
var image = "<img src=" + truejson.thumbnail_url + " alt=" + truejson.name + "/>";
$("div#previewIe").html(image);
} else {
var parsedjson = JSON.parse(data);
var truejson = parsedjson[0];
var image = "<img src=" + truejson.thumbnail_url + " alt=" + truejson.name + "/>";
$("div#previewIe").html(image);
}
}
});
}
Upvotes: 2
Reputation: 3917
You are using the jQuery Form Plugin. As stated by Kyle, json2.js is irrelevant here.
IE9 does not support submitting files via ajax.
So the jQuery Form Plugin submits the form to a hidden iframe as a workaround, which has its limitations. These limitations are what you're running in to.
This is fine if the response type is HTML or XML, but doesn't work as well if the response type is script or JSON, both of which often contain characters that need to be repesented using entity references when found in HTML markup.
Upvotes: 0