37

I have an array like this:

array = ["123", "456", "#123"]

I want to find the element which contains the substring "#". I tried array.includes("#") and array.indexOf("#") but it didn't work.

How can I check if any of the strings in this array contain the substring "#"?

ggorlen
  • 33,459
  • 6
  • 59
  • 67
user7334203
  • 6,006
  • 20
  • 46
  • 97

5 Answers5

64

Because includes will compare '#' with each array element.

Let's try with some or find if you want to find if you want to get exactly element

var array = ["123", "456", "#123"];

var el = array.find(a =>a.includes("#"));

console.log(el)
taile
  • 2,598
  • 16
  • 28
14

There appears to be multiple questions here since the title and post body differ. Do you want to know if the array has an element or do you want to get the element itself? If you want to get an element, which one(s) do you want -- the first occurrence, the last occurrence or an array of all occurrences?

This post is intended as a resource for future visitors who might not necessarily want to find (i.e. return the first element from the left) as the top answer shows. To elaborate on that answer, there's a gotcha with indiscriminately replacing some with find in a boolean context -- the element returned may be falsey as in

if ([5, 6, 0].find(e => e < 3)) { // fix: use `some` instead of `find`
  console.log("you might expect this to run");
}
else {
  console.log("but this actually runs " +
    "because the found element happens to be falsey");
}

Note that e => e.includes("#") can be substituted with any predicate, so it's largely incidental to the question.


Does any element match the predicate?

const array = ["123", "456", "#123"];
console.log(array.some(e => e.includes("#"))); // true
console.log(array.some(e => e.includes("foobar"))); // false

MDN: Array.prototype.some()

Does every element match the predicate?

const array = ["123", "456", "#123"];
console.log(array.every(e => e.includes("#"))); // false
console.log(array.every(e => /\d/.test(e))); // true

MDN: Array.prototype.every()

What is the first element that matches the predicate?

const array = ["123", "456", "#123", "456#"];
console.log(array.find(e => e.includes("#"))); // "#123"
console.log(array.find(e => e.includes("foobar"))); // undefined

MDN: Array.prototype.find()

What is the index of the first element that matches the predicate?

const array = ["123", "456", "#123", "456#"];
console.log(array.findIndex(e => e.includes("#"))); // 2
console.log(array.findIndex(e => e.includes("foobar"))); // -1

MDN: Array.prototype.findIndex()

What are all the elements that match the predicate?

const array = ["123", "456", "#123", "456#"];
console.log(array.filter(e => e.includes("#"))); // ["#123", "456#"]
console.log(array.filter(e => e.includes("foobar"))); // []

MDN: Array.prototype.filter()

What are the indices of all of the elements that match the predicate?

const filterIndices = (a, pred) => a.reduce((acc, e, i) => {
  pred(e, i, a) && acc.push(i);
  return acc;
}, []);

const array = ["123", "456", "#123", "456#"];
console.log(filterIndices(array, e => e.includes("#"))); // [2, 3]
console.log(filterIndices(array, e => e.includes("foobar"))); // []

MDN: Array.prototype.reduce()

What is the last element that matches the predicate?

const findLast = (a, pred) => {
  for (let i = a.length - 1; i >= 0; i--) {
    if (pred(a[i], i, a)) {
      return a[i];
    }
  }
};

const array = ["123", "456", "#123", "456#"];
console.log(findLast(array, e => e.includes("#"))); // "456#"
console.log(findLast(array, e => e.includes("foobar"))); // undefined

What is the index of the last element that matches the predicate?

const findLastIndex = (a, pred) => {
  for (let i = a.length - 1; i >= 0; i--) {
    if (pred(a[i], i, a)) {
      return i;
    }
  }

  return -1;
};

const array = ["123", "456", "#123", "456#"];
console.log(findLastIndex(array, e => e.includes("#"))); // 3
console.log(findLastIndex(array, e => e.includes("foobar"))); // -1
ggorlen
  • 33,459
  • 6
  • 59
  • 67
2

You can use join method:

array.join('').indexOf("#")
cigien
  • 55,661
  • 11
  • 60
  • 99
2

Use Array.some:

array.some((item) => item.includes('#'));

It just checks if some item includes '#' - readable and clear.

-1

You can use filter ().

    var array = ["123", "456", "#123"];

    console.log(array.filter(function(item){
        var finder = '#';
        return eval('/'+finder+'/').test(item);
    }));

By passing a function you can filter and return the elements that match what you are looking for.

In this example, I made use of eval (), just because to fetch the string use RegExp, but could fetch with the == operator.

GeekSilva
  • 412
  • 5
  • 19
  • 5
    why eval? {}{}{{} – shinzou Apr 24 '18 at 13:31
  • Use `new RegExp()` instead of `eval`, or even better just use `includes`. If the substring happens to have special regex characters, the regex approach breaks, so this answer is pretty broken on a couple of levels. – ggorlen May 02 '21 at 00:25