ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript はオブジェクトが配列であるかどうかを判断します

JavaScript はオブジェクトが配列であるかどうかを判断します

黄舟
黄舟オリジナル
2017-02-24 13:09:49918ブラウズ


1. typeof

データ型を検出するには、まず typeof を使用することが考えられますが、Function、String、Number、Unknown などの基本的な型については、typeof を使用して検出できます。コードは次のとおりです:

function test(){}
console.log(typeof 1); // number
console.log(typeof test); // function 
console.log(typeof "yunxi"); // string
console.log(typeof undefined); // undefined

しかし、配列または正規表現の場合、typeof を使用してそれらを検出することは満足のいくものではありません。配列または正規表現を検出すると、返される型は次のコードに示すようにオブジェクトになるためです。 :

console.log(typeof []);  // object
console.log(typeof /\d+/g); // object

2. Instanceof

このことから、オブジェクトが配列のインスタンスであるかどうかを検出するために、instanceof を使用すると簡単に考えることができます。配列の場合は true を返し、それ以外の場合は true を返します。 false を返します。次のように、配列であるかどうかを検出するための上記のコードを見てみましょう:

console.log([] instanceof Array);  // true
console.log(/\d+/g instanceof Array); // false

上記からわかるように、instanceof を使用すると、実際にそれが配列要素であるかどうかを判断できます

3。

JavaScriptでは、各オブジェクトにはコンストラクター属性があり、未知のオブジェクトの型を決定するなど、オブジェクトを初期化するコンストラクターを参照します。そのため、次のようにメソッドを記述できます。コードは次のとおりです:

function isArray(obj) {
    return typeof obj == 'object' && obj.constructor == Array
}
// 测试demo
console.log(isArray([])); // true
var a = {"a":1};
console.log(isArray(a)); // false

var b = [1,2,3];
console.log(isArray(b)); // true
console.log(isArray(/\d+/g));// false

上記でわかるように、配列の isArray メソッドを呼び出すことで、それがどうかを判断することもできます。

2 番目と 3 番目のポイントでは、instanceof メソッドとコンストラクター属性をそれぞれ使用すると、それが配列であるかどうかを判断できるようですが、クロスフレームを使用する場合にページを使用するなどの例外もあります。 iframe 配列、異なる iframe で作成された配列はプロトタイプ属性を互いに共有しないため、失敗します。次のコード テストで検証できます~

var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;       
var arr = new xArray("1","2","3","4","5");
//这个写法IE下是不支持的,标准浏览器firefox,chrome下有

console.log(arr);  // 打印出 ["1", "2", "3", "4", "5"]
console.log(arr instanceof Array); // false 
console.log(arr.constructor === Array); // false

上記のメソッド Array メソッドを使用してオブジェクトであるかどうかを判断することはできません。しかし、ECMA262 では、Object.prototype.toString.call() メソッドを使用して、オブジェクトが配列であるかどうかを判断できることがわかります。次のコード:

function isArray(obj) {
    return Object.prototype.toString.call(obj) == '[object Array]';
}
// 代码调用
console.log(isArray([]));  // true
console.log(isArray([1,2,3])); // true

var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;       
var arr = new xArray("1","2","3","4","5");

console.log(arr); // ["1","2","3","4","5"]
console.log(isArray(arr));  // true

上記は、JavaScript がオブジェクトが配列であるかどうかを判断する方法です。 、その他の関連コンテンツについては、PHP 中国語 Web サイト (www.php.cn) に注目してください。


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。