I've use token input in my website, and here's how I initialize the token input:
$(document).ready(function () {
var populateValue = document.getElementById('<%= hiddentokenPrePopulate.ClientID%>').value
$("#<%= tokenEmployee.ClientID%>").tokenInput("../Employee/getEmployeeDetails.ashx", {
deleteText: "X",
theme: "facebook",
preventDuplicates: true,
tokenDelimiter: ";",
minChars: 3,
tokenLimit: 1,
prePopulate: populateValue
});
});
The script was stuck on this line:
prePopulate: populateValue
When I remove this line, there won't be any javascript error, but I need this as I need to pre-populate the token input. The populateValue
is:
[{
"id": "11566",
"name": "Smith - White"
}]
There was a javascript error:
Uncaught TypeError: Cannot use 'in' operator to search for '47' in [{"id":"11566","name":"Smith - White"}]`
How can I fix this error?
You may get this error if you are using a string as an array. Say that if you got a json from an ajax, and you forgot to parse the result, and using the result as an array. The remedy is as above, to parse the json before using it.
You need to parse the string in your
populateValue
variable to an object:Or alternatively, in plain JS:
Your server side code means .CS page where you have written your WebMethod, should always return
.ToList()
means array of jsonHere is my .CS page code:
WebMethod
Then in my jQuery post method:
I was getting this error as well.
C# Api returning Serialized Dictionary data.
Kept on getting this error message, until i just returned the Dictionary data directly without trying to Serialize
No more errors on the browser side. Not sure why.