Uncaught SyntaxError: Unexpected token with JSON.parse

JavascriptJqueryJson

Javascript Problem Overview


what causes this error on the third line?

var products = [{
  "name": "Pizza",
  "price": "10",
  "quantity": "7"
}, {
  "name": "Cerveja",
  "price": "12",
  "quantity": "5"
}, {
  "name": "Hamburguer",
  "price": "10",
  "quantity": "2"
}, {
  "name": "Fraldas",
  "price": "6",
  "quantity": "2"
}];
console.log(products);
var b = JSON.parse(products); //unexpected token o

Open console to view error

Javascript Solutions


Solution 1 - Javascript

products is an object. (creating from an object literal)

JSON.parse() is used to convert a string containing JSON notation into a Javascript object.

Your code turns the object into a string (by calling .toString()) in order to try to parse it as JSON text.
The default .toString() returns "[object Object]", which is not valid JSON; hence the error.

Solution 2 - Javascript

Let's say you know it's valid JSON but your are still getting this...

In that case it's likely that there are hidden/special characters in the string from whatever source your getting them. When you paste into a validator, they are lost - but in the string they are still there. Those chars, while invisible, will break JSON.parse()

If s is your raw JSON, then clean it up with:

// preserve newlines, etc - use valid JSON
s = s.replace(/\\n/g, "\\n")  
               .replace(/\\'/g, "\\'")
               .replace(/\\"/g, '\\"')
               .replace(/\\&/g, "\\&")
               .replace(/\\r/g, "\\r")
               .replace(/\\t/g, "\\t")
               .replace(/\\b/g, "\\b")
               .replace(/\\f/g, "\\f");
// remove non-printable and other non-valid JSON chars
s = s.replace(/[\u0000-\u0019]+/g,""); 
var o = JSON.parse(s);

Solution 3 - Javascript

It seems you want to stringify the object, not parse. So do this:

JSON.stringify(products);

The reason for the error is that JSON.parse() expects a String value and products is an Array.

Note: I think it attempts json.parse('[object Array]') which complains it didn't expect token o after [.

Solution 4 - Javascript

I found the same issue with JSON.parse(inputString).

In my case the input string is coming from my server page [return of a page method].

I printed the typeof(inputString) - it was string, still the error occurs.

I also tried JSON.stringify(inputString), but it did not help.

Later I found this to be an issue with the new line operator [\n], inside a field value.

I did a replace [with some other character, put the new line back after parse] and everything is working fine.

Solution 5 - Javascript

JSON.parse is waiting for a String in parameter. You need to stringify your JSON object to solve the problem.

products = [{"name":"Pizza","price":"10","quantity":"7"}, {"name":"Cerveja","price":"12","quantity":"5"}, {"name":"Hamburguer","price":"10","quantity":"2"}, {"name":"Fraldas","price":"6","quantity":"2"}];
console.log(products);
var b = JSON.parse(JSON.stringify(products));  //solves the problem

Solution 6 - Javascript

You should validate your JSON string here.

A valid JSON string must have double quotes around the keys:

JSON.parse({"u1":1000,"u2":1100})       // will be ok

If there are no quotes, it will cause an error:

JSON.parse({u1:1000,u2:1100})    
// error Uncaught SyntaxError: Unexpected token u in JSON at position 2

Using single quotes will also cause an error:

JSON.parse({'u1':1000,'u2':1100})    
// error Uncaught SyntaxError: Unexpected token ' in JSON at position 1

Solution 7 - Javascript

products = [{"name":"Pizza","price":"10","quantity":"7"}, {"name":"Cerveja","price":"12","quantity":"5"}, {"name":"Hamburguer","price":"10","quantity":"2"}, {"name":"Fraldas","price":"6","quantity":"2"}];

change to

products = '[{"name":"Pizza","price":"10","quantity":"7"}, {"name":"Cerveja","price":"12","quantity":"5"}, {"name":"Hamburguer","price":"10","quantity":"2"}, {"name":"Fraldas","price":"6","quantity":"2"}]';

Solution 8 - Javascript

If there are leading or trailing spaces, it'll be invalid. Trailing/Leading spaces can be removed as

mystring = mystring.replace(/^\s+|\s+$/g, "");

Source: http://www.toptip.ca/2010/02/javascript-trim-leading-or-trailing.html

Solution 9 - Javascript

Here's a function I made based on previous replies: it works on my machine but YMMV.

          /**
             * @description Converts a string response to an array of objects.
             * @param {string} string - The string you want to convert.
             * @returns {array} - an array of objects.
            */
            function stringToJson(input) {
              var result = [];
            
              //replace leading and trailing [], if present
              input = input.replace(/^\[/,'');
              input = input.replace(/\]$/,'');
            
              //change the delimiter to 
              input = input.replace(/},{/g,'};;;{');
            
              // preserve newlines, etc - use valid JSON
              //https://stackoverflow.com/questions/14432165/uncaught-syntaxerror-unexpected-token-with-json-parse
            input = input.replace(/\\n/g, "\\n")  
            .replace(/\\'/g, "\\'")
            .replace(/\\"/g, '\\"')
            .replace(/\\&/g, "\\&")
            .replace(/\\r/g, "\\r")
            .replace(/\\t/g, "\\t")
            .replace(/\\b/g, "\\b")
            .replace(/\\f/g, "\\f");
            // remove non-printable and other non-valid JSON chars
            input = input.replace(/[\u0000-\u0019]+/g,""); 
            
              input = input.split(';;;');
            
              input.forEach(function(element) {
                // console.log(JSON.stringify(element));
                
                result.push(JSON.parse(element));
              }, this);

              return result;
            }

Solution 10 - Javascript

One other gotcha that can result in "SyntaxError: Unexpected token" exception when calling JSON.parse() is using any of the following in the string values:

  1. New-line characters.

  2. Tabs (yes, tabs that you can produce with the Tab key!)

  3. Any stand-alone slash \ (but for some reason not /, at least not on Chrome.)

(For a full list see the String section here.)

For instance the following will get you this exception:

{
	"msg" : {
		"message": "It cannot
contain a new-line",
		"description": "Some discription with a		tabbed space is also bad",
		"value": "It cannot have 3\4 un-escaped"
	}
}

So it should be changed to:

{
	"msg" : {
		"message": "It cannot\ncontain a new-line",
		"description": "Some discription with a\t\ttabbed space",
		"value": "It cannot have 3\\4 un-escaped"
	}
}

Which, I should say, makes it quite unreadable in JSON-only format with larger amount of text.

Solution 11 - Javascript

[  {    "name": "Pizza",    "price": "10",    "quantity": "7"  },  {    "name": "Cerveja",    "price": "12",    "quantity": "5"  },  {    "name": "Hamburguer",    "price": "10",    "quantity": "2"  },  {    "name": "Fraldas",    "price": "6",    "quantity": "2"  }]

Here is your perfect Json that you can parse.

Solution 12 - Javascript

Hopefully this helps someone else.

My issue was that I had commented HTML in a PHP callback function via AJAX that was parsing the comments and return invalid JSON.

Once I removed the commented HTML, all was good and the JSON was parsed with no issues.

Solution 13 - Javascript

When you are using POST or PUT method, make sure to stringify the body part.

I have documented an example here https://gist.github.com/manju16832003/4a92a2be693a8fda7ca84b58b8fa7154

Solution 14 - Javascript

The only mistake you are doing is, you are parsing already parsed object so it's throwing error, use this and you will be good to go.

var products = [{
  "name": "Pizza",
  "price": "10",
  "quantity": "7"
}, {
  "name": "Cerveja",
  "price": "12",
  "quantity": "5"
}, {
  "name": "Hamburguer",
  "price": "10",
  "quantity": "2"
}, {
  "name": "Fraldas",
  "price": "6",
  "quantity": "2"
}];
console.log(products[0].name); //name of item at 0th index

if you want to print entire json then use JSON.stringify()

Solution 15 - Javascript

products is an array which can be used directly:

var i, j;

for(i=0;i<products.length;i++)
  for(j in products[i])
    console.log("property name: " + j,"value: "+products[i][j]);

Solution 16 - Javascript

Now apparently \r, \b, \t, \f, etc aren't the only problematic chars that can give you this error.

Note that some browsers may have additional requirements for the input of JSON.parse.

Run this test code on your browser:

var arr = [];
for(var x=0; x < 0xffff; ++x){
    try{
        JSON.parse(String.fromCharCode(0x22, x, 0x22));
    }catch(e){
        arr.push(x);
    }
}
console.log(arr);

Testing on Chrome, I see that it doesn't allow JSON.parse(String.fromCharCode(0x22, x, 0x22)); where x is 34, 92, or from 0 to 31.

Chars 34 and 92 are the " and \ characters respectively, and they are usually expected and properly escaped. It's chars 0 to 31 that would give you problems.

To help with debugging, before you do JSON.parse(input), first verify that the input doesn't contain problematic characters:

function VerifyInput(input){
    for(var x=0; x<input.length; ++x){
        let c = input.charCodeAt(x);
        if(c >= 0 && c <= 31){
            throw 'problematic character found at position ' + x;
        }
    }
}

Solution 17 - Javascript

Oh man, solutions in all above answers provided so far didn't work for me. I had a similar problem just now. I managed to solve it with wrapping with the quote. See the screenshot. Whoo.

enter image description here

Original:

var products = [{
  "name": "Pizza",
  "price": "10",
  "quantity": "7"
}, {
  "name": "Cerveja",
  "price": "12",
  "quantity": "5"
}, {
  "name": "Hamburguer",
  "price": "10",
  "quantity": "2"
}, {
  "name": "Fraldas",
  "price": "6",
  "quantity": "2"
}];
console.log(products);
var b = JSON.parse(products); //unexpected token o

Solution 18 - Javascript

The error you are getting i.e. "unexpected token o" is because json is expected but object is obtained while parsing. That "o" is the first letter of word "object".

Solution 19 - Javascript

It can happen for a lot of reasons, but probably for an invalid char, so you can use JSON.stringify(obj); that will turn your object into a JSON but remember that it is a JQUERY expression.

Solution 20 - Javascript

In my case there is following character problems in my JSON string

  1. \r
  2. \t
  3. \r\n
  4. \n
  5. :
  6. "

I have replaced them with another characters or symbols, and then revert back again from coding.

Solution 21 - Javascript

This is now a JavaScript Array of Object, not JSON format. TO convert it into JSON format you need to use a function called JSON.stringify()

JSON.stringify(products)

Solution 22 - Javascript

Why you need JSON.parse? It's already in array of object format.

Better use JSON.stringify as below : var b = JSON.stringify(products);

This may help you.

Solution 23 - Javascript

The mistake I was doing was passing null (unknowingly) into JSON.parse().

So it threw Unexpected token n in JSON at position 0

But this happens whenever you pass something which is not JS Object in JSON.parse()

Solution 24 - Javascript

Use eval. It takes JavaScript expression/code as string and evaluates/executes it.

eval(inputString);

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestioncoisoView Question on Stackoverflow
Solution 1 - JavascriptSLaksView Answer on Stackoverflow
Solution 2 - JavascriptEdHView Answer on Stackoverflow
Solution 3 - JavascriptOnur YıldırımView Answer on Stackoverflow
Solution 4 - JavascriptDerinView Answer on Stackoverflow
Solution 5 - JavascriptTérenceView Answer on Stackoverflow
Solution 6 - JavascripthoogwView Answer on Stackoverflow
Solution 7 - JavascriptpktangyueView Answer on Stackoverflow
Solution 8 - JavascriptattView Answer on Stackoverflow
Solution 9 - JavascripttmurphreeView Answer on Stackoverflow
Solution 10 - Javascriptc00000fdView Answer on Stackoverflow
Solution 11 - JavascriptSanView Answer on Stackoverflow
Solution 12 - JavascriptChrisView Answer on Stackoverflow
Solution 13 - JavascriptManjunath ReddyView Answer on Stackoverflow
Solution 14 - JavascriptKiran ManiyaView Answer on Stackoverflow
Solution 15 - Javascriptic3b3rgView Answer on Stackoverflow
Solution 16 - JavascriptPacerierView Answer on Stackoverflow
Solution 17 - JavascriptWell SmithView Answer on Stackoverflow
Solution 18 - JavascriptShashank BodkheView Answer on Stackoverflow
Solution 19 - JavascriptElvis Silva NoletoView Answer on Stackoverflow
Solution 20 - JavascriptFaraz AhmedView Answer on Stackoverflow
Solution 21 - JavascriptMD SHAYONView Answer on Stackoverflow
Solution 22 - JavascriptAbhijit PadhyView Answer on Stackoverflow
Solution 23 - JavascriptAashutosh RathiView Answer on Stackoverflow
Solution 24 - JavascriptKasthuriView Answer on Stackoverflow