目前我使用的是Angular 2.0。我有一个数组如下:

var channelArray: Array<string> = ['one', 'two', 'three'];

如何在TypeScript中检查channelArray是否包含字符串' 3 '?


你可以使用some方法:

console.log(channelArray.some(x => x === "three")); // true

你可以使用find方法:

console.log(channelArray.find(x => x === "three")); // three

或者你可以使用indexOf方法:

console.log(channelArray.indexOf("three")); // 2

与JavaScript中使用Array.prototype.indexOf()相同:

console.log(channelArray.indexOf('three') > -1);

或者使用ECMAScript 2016 Array.prototype.includes():

console.log(channelArray.includes('three'));

注意,你也可以使用@Nitzan所显示的方法来查找字符串。但是,通常不会对字符串数组这样做,而是对对象数组这样做。在那里,这些方法更为合理。例如

const arr = [{foo: 'bar'}, {foo: 'bar'}, {foo: 'baz'}];
console.log(arr.find(e => e.foo === 'bar')); // {foo: 'bar'} (first match)
console.log(arr.some(e => e.foo === 'bar')); // true
console.log(arr.filter(e => e.foo === 'bar')); // [{foo: 'bar'}, {foo: 'bar'}]

参考

Array.find ()

Array.some ()

Array.filter ()


如果你的代码是基于ES7(或更高版本):

channelArray.includes('three'); //will return true or false

如果不是,例如你正在使用没有babel transpile的IE:

channelArray.indexOf('three') !== -1; //will return true or false

indexOf方法将返回元素在数组中的位置,因为如果在第一个位置找到指针,我们使用的是不同于-1的!==。


这样做:

departments: string[]=[];
if(this.departments.indexOf(this.departmentName.trim()) >-1 ){
            return;
    }

还要注意,“in”关键字对数组不起作用。它只对对象有效。

propName in myObject

数组包含测试为

myArray.includes('three');

使用JavaScript数组include()方法

var fruits = ["Banana", "Orange", "Apple", "Mango"];
var n = fruits.includes("Mango");

自己试试»链接

定义

includes()方法确定数组中是否包含指定元素。

如果数组中包含该元素,则该方法返回true,否则返回false。


TS有许多数组的实用方法,这些方法可以通过数组的原型得到。有多种方法可以实现这一目标,但最方便的两种方法是:

array . indexof()接受任意值作为参数,然后返回数组中给定元素所在的第一个下标,如果不存在则返回-1。 include()接受任何值作为参数,然后确定数组是否包含this值。如果找到值,方法返回true,否则返回false。

例子:

const channelArray: string[] = ['one', 'two', 'three'];

console.log(channelArray.indexOf('three'));      // 2
console.log(channelArray.indexOf('three') > -1); // true
console.log(channelArray.indexOf('four') > -1);  // false
console.log(channelArray.includes('three'));     // true

你也可以使用滤镜

this.products = array_products.filter((x) => x.Name.includes("ABC"))

使用findIndex方法,我们可以获得数组的索引,从而使用startsWith方法实现比较

Const array = ["one", "two", "three"]; const myArray = (arr, v) => { 返回arr.findIndex((item) => item. startswith (v)) > -1; }; console.log (myArray(数组," 5 "));/ /错误 console.log (myArray(数组”,两个“));/ /正确的 console.log (myArray([],“两”));/ /错误