回答:
いいえ、ありません。このため、ほとんどの一般的なライブラリには、ユーティリティパッケージに含まれています。例として、jQueryのinArrayおよびプロトタイプのArray.indexOfを確認してください。
jQueryの実装は、予想どおり簡単です。
function inArray(needle, haystack) {
var length = haystack.length;
for(var i = 0; i < length; i++) {
if(haystack[i] == needle) return true;
}
return false;
}
配列要素の量が非常に多い場合は、上記の方法でうまくいきます。
編集:おっと。配列が別の配列の中にあるかどうかを確認したいとは思いもしませんでした。PHPのドキュメントによると、これはPHPの予想される動作ですin_array
。
$a = array(array('p', 'h'), array('p', 'r'), 'o');
if (in_array(array('p', 'h'), $a)) {
echo "'ph' was found\n";
}
if (in_array(array('f', 'i'), $a)) {
echo "'fi' was found\n";
}
if (in_array('o', $a)) {
echo "'o' was found\n";
}
// Output:
// 'ph' was found
// 'o' was found
ChrisとAlexによって投稿されたコードは、この動作に従いません。AlexはプロトタイプのindexOfの公式バージョンであり、ChrisはPHPに似ていますarray_intersect
。これはあなたが望むことをします:
function arrayCompare(a1, a2) {
if (a1.length != a2.length) return false;
var length = a2.length;
for (var i = 0; i < length; i++) {
if (a1[i] !== a2[i]) return false;
}
return true;
}
function inArray(needle, haystack) {
var length = haystack.length;
for(var i = 0; i < length; i++) {
if(typeof haystack[i] == 'object') {
if(arrayCompare(haystack[i], needle)) return true;
} else {
if(haystack[i] == needle) return true;
}
}
return false;
}
そして、これに関する上記の私のテスト:
var a = [['p','h'],['p','r'],'o'];
if(inArray(['p','h'], a)) {
alert('ph was found');
}
if(inArray(['f','i'], a)) {
alert('fi was found');
}
if(inArray('o', a)) {
alert('o was found');
}
// Results:
// alerts 'ph' was found
// alerts 'o' was found
Arrayプロトタイプを拡張することは、一般的にそうするのが悪いため、意図的に拡張しなかったことに注意してください。
indexOf
w3schools.com/jsref/jsref_indexof_array.aspの
現在ありますArray.prototype.includes
:
include()メソッドは、配列に特定の要素が含まれているかどうかを判別し、必要に応じてtrueまたはfalseを返します。
var a = [1, 2, 3];
a.includes(2); // true
a.includes(4); // false
構文
arr.includes(searchElement)
arr.includes(searchElement, fromIndex)
Array.indexOf
はJavaScript 1.6で導入されましたが、古いブラウザではサポートされていません。ありがたいことに、Mozillaでの打ちのめしはあなたのためにすべての大変な仕事をし、互換性のためにこれを提供しました:
if (!Array.prototype.indexOf)
{
Array.prototype.indexOf = function(elt /*, from*/)
{
var len = this.length >>> 0;
var from = Number(arguments[1]) || 0;
from = (from < 0)
? Math.ceil(from)
: Math.floor(from);
if (from < 0)
from += len;
for (; from < len; from++)
{
if (from in this &&
this[from] === elt)
return from;
}
return -1;
};
}
スクリプティングを楽しむための便利な使用スニペットもいくつかあります。
this.length >>> 0
何ですか?それは数値型への変換ですか?
Array.indexOf
ECMAScript Fifth Editionによって標準化されたため、適切な「ネイティブ」な方法と見なす必要があります。ただし、長い間、古いブラウザのスニッフィングとバックアップを提供する必要があります。@harto:はい、this.length
32ビットの符号なし整数として表現できるNumber に変換されます。ネイティブArray
は、すでにこれに準拠している長さしか持てませんが、仕様では、Array.prototype
ネイティブでないJSオブジェクトでメソッドを呼び出すことができるとしていArray
ます。これとその他の面倒な引数チェックは、完全な仕様準拠を保証するためのものです。
インデックスが連続していない場合、またはインデックスが連続していない場合、ここに記載されている他のソリューションのコードは機能しなくなります。多少良くなる解決策は次のようになるでしょう:
function in_array(needle, haystack) {
for(var i in haystack) {
if(haystack[i] == needle) return true;
}
return false;
}
そしておまけとして、これはPHPのarray_searchと同等のものです(配列内の要素のキーを見つけるために:
function array_search(needle, haystack) {
for(var i in haystack) {
if(haystack[i] == needle) return i;
}
return false;
}
Locutusというプロジェクトがあり、JavascriptでPHP関数を実装し、in_array()が含まれているため、PHPで使用するのとまったく同じように使用できます。
使用例:
in_array('van', myArray);
in_array(1, otherArray, true); // Forcing strict type
このレッスンのw3schoolsで説明されているように、単純に「includes」関数を使用できます。
のように見えます
let myArray = ['Kevin', 'Bob', 'Stuart'];
if( myArray.includes('Kevin'))
console.log('Kevin is here');
var a = [1,2,3,4,5,6,7,8,9];
var isSixInArray = a.filter(function(item){return item==6}).length ? true : false;
var isSixInArray = a.indexOf(6)>=0;
jQueryソリューションが利用可能です。ドキュメントをここで確認してください:http ://api.jquery.com/jquery.inarray/
$.inArray( 10, [ 8, 9, 10, 11 ] );
同等の関数があります:
includes()
こちらをご覧ください:https : //developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/includes
単一の値が配列に含まれているかどうかを確認するだけの場合は、Paoloのコードが役立ちます。両方の配列に共通する値を確認する場合は、次のようなものが必要になります(PaoloのinArray関数を使用)。
function arrayIntersect(a, b) {
var intersection = [];
for(var i = 0; i < a.length; i++) {
if(inArray(b, a[i]))
intersection.push(a[i]);
}
return intersection;
}
これは、両方にある値の配列戻りウィルa
とをb
。(数学的には、これは2つの配列の共通部分です。)
編集:問題の解決策については、Paoloの編集済みコードを参照してください。:)
PHPで使用可能なすべてのパラメーターが必要な場合は、次のように使用します。
function in_array(needle, haystack, argStrict) {
var key = '', strict = !!argStrict;
if (strict) {
for (key in haystack) {
if (haystack[key] === needle) {
return true;
}
}
}
else {
for (key in haystack) {
if (haystack[key] == needle) {
return true;
}
}
}
return false;
}
このコードをプロジェクトに追加し、オブジェクトスタイルのinArrayメソッドを使用します
if (!Array.prototype.inArray) {
Array.prototype.inArray = function(element) {
return this.indexOf(element) > -1;
};
}
//How it work
var array = ["one", "two", "three"];
//Return true
array.inArray("one");
道場ツールキット、あなたが使用しますdojo.indexOf()
。ドキュメントについてはdojo.indexOfを、いくつかの例についてはBryan Forbesによって作成された配列を参照してください。
haystack.find(value => value == needle)
ここで、haystackは配列で、needleは配列の要素です。要素が見つからない場合は未定義で返され、それ以外の場合は同じ要素が返されます。
function in_array(needle, haystack){
return haystack.indexOf(needle) !== -1;
}
indexOf(needle) > 0
falseが返される場合
jQuery.inArray()
ブール値を返しません。見つかった要素のインデックスを返します。見つからなかった場合は-1を返します