9

Code:

function showlayer(name){
    var size = js_array.length
    var index = js_array.indexOf(name);
    var plusOne = js_array[index+1];
    document.write("" + name + "<br />" + js_array + "<br />" + index + "<br />" +
                   plusOne + "<br />" )
    ...
}

Output:

301
300,299,301,290,303,304,302,310,291,306,308,305,307,292,294,295,309
-1
300

All possible values of name are in the array, but for some reason indexOf() never finds them. Whats up?

gta0004
  • 508
  • 4
  • 11
  • 29
  • Are you comparing numbers to strings? – SLaks Jan 29 '13 at 20:57
  • 1
    This isn't the problem you are specifically seeing here, but it is worth pointing out that `Array.indexOf()` isn't available on IE8 and lower. See here: http://stackoverflow.com/questions/2790001/fixing-javascript-array-functions-in-internet-explorer-indexof-foreach-etc. – pseudosavant Jan 29 '13 at 21:45
  • @pseudosavant Yeah I know. Hope it won't be too much of an issue – gta0004 Jan 29 '13 at 23:47
  • That stackoverflow link has a polyfill to add support for `Array.indexOf()` to IE6-8 if you need it. I prefer to only support IE9 and up now-a-days, but there are still a lot of IE8 people out there. – pseudosavant Jan 30 '13 at 17:31

1 Answers1

29

Try this instead:

...
var index = js_array.indexOf(parseInt(name, 10)); // so that it does not try to compare strings...
...
Naftali
  • 144,921
  • 39
  • 244
  • 303