Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
126 views
in Technique[技术] by (71.8m points)

javascript - JS: unsure why function is returning

Really novice question but why is my function returning with -1? The function does have a match so why is the function returning -1 instead of the index value. If I remove the else statement it returns with the correct out output.

let array = [1, 2, 3, 4, 5, 6, 7, 8, 9];
let target = 5;

function search() {
  for (let i = 0; i < array.length; i++) {
    if (array[i] === target) {
      console.log(true);
      return array.indexOf(array[i]);
    } else {
      console.log(false);
      return -1;
    }
  }
}

search();

question from:https://stackoverflow.com/questions/65860387/js-unsure-why-function-is-returning

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

You are checking the first element (index i = 0) against the target. If they don't match, you call return -1. return immediately exists the function. You probably want to place your return after the loop.

let array = [1, 2, 3, 4, 5, 6, 7, 8, 9];
let target = 5;

function search() {
  for (let i = 0; i < array.length; i++) {
    if (array[i] === target) {
      console.log(true);
      return i;
    } 
  }

  console.log(false);
  return -1;

}

search();

Furhtermore it's not necessary to do array.indexOf inside the loop, because if array[i] == target you already have the correct index i


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...