programing

TypeScript에 배열에 문자열이 포함되어 있는지 어떻게 확인합니까?

new-time 2020. 5. 12. 22:10
반응형

TypeScript에 배열에 문자열이 포함되어 있는지 어떻게 확인합니까?


현재 Angular 2.0을 사용하고 있습니다. 다음과 같은 배열이 있습니다.

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

channelArray에 'three'문자열이 포함되어 있는지 TypeScript에서 어떻게 확인할 수 있습니까?


 

Array.prototype.indexOf ()를

사용하는 JavaScript와 동일합니다 .

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 ()


 

몇 가지 방법을

사용할 수 있습니다 .

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

 

find 메소드를

사용할 수 있습니다 .

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

또는

indexOf 메소드를

사용할 수 있습니다 .

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

코드가 ES7 기반 인 경우 :

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

그렇지 않은 경우, 예를 들어 babel transpile없이 IE를 사용하는 경우 :

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

indexOf

메소드는 요소가 배열에있는 위치를 반환합니다. 왜냐하면

!==

바늘이 첫 번째 위치에서 발견되면 -1과 다른 값을 사용하기 때문입니다 .


또한

"in"키워드

는 배열에서 작동하지 않습니다. 객체에서만 작동합니다.

propName in myObject

배열 포함 테스트는

myArray.includes('three');

를 사용하여

자바 스크립트 배열 () 포함

방법

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

직접 해보기»

링크

정의

 

포함 ()

메소드는 배열 지정된 요소가 포함되어 있는지 여부를 판정한다.이 메소드는 배열에 요소가 포함되어 있으면 true를, 그렇지 않으면 false를 리턴합니다.


이렇게하십시오 :

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

TS에는 어레이 프로토 타입을 통해 사용할 수있는 어레이에 대한 많은 유틸리티 방법이 있습니다. 이 목표를 달성 할 수있는 여러 가지가 있지만이 목적에 가장 편리한 두 가지는 다음과 같습니다.

  1. Array.indexOf() 임의의 값을 인수로 사용하여 주어진 요소가 배열에서 발견 될 수있는 첫 번째 색인을 리턴하거나 존재하지 않는 경우 -1을 리턴합니다.
  2. Array.includes()값을 인수로 사용하여 배열에이 값이 포함되어 있는지 여부를 확인합니다. true값이 발견 되면를 반환 하고 그렇지 않으면를 반환 false합니다.

예:

var 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'));     // ture

참고 URL :

https://stackoverflow.com/questions/42790602/how-do-i-check-whether-an-array-contains-a-string-in-typescript

반응형