ホームページ  >  記事  >  ウェブフロントエンド  >  jsのデータ型と配列メソッドインスタンスの判断方法を詳しく解説

jsのデータ型と配列メソッドインスタンスの判断方法を詳しく解説

伊谢尔伦
伊谢尔伦オリジナル
2017-07-18 11:37:221636ブラウズ

データ型判定 typeof

typeof は、ほとんどのデータ型の判定を解決できます。その戻り値は、オペランドの型を表す文字列です。


//判断变量num是不是一个数字类型
if(typeof num=='number') {
  return true;
}

戻り結果:


var a="hling"; console.log(a); //string
var a=1; console.log(a); //number
var a=false; console.log(a); //boolean
var a; console.log(typeof a); //undfined
var a = null; console.log(typeof a); //object
var a = document; console.log(typeof a); //object
var a = []; console.log(a); //object
var a = function(){}; console.log(typeof a) 
//function除了可以判断数据类型还可以判断function类型

文字列、数値、ブール値、未定義の 4 つの型に加えて、null、オブジェクト、配列はすべてオブジェクト型を返します。 ! !

関数型の場合、typeof(Date)、typeof(eval) などの関数が返されます。配列の型を決定する

jsメソッド

1)instanceof

instanceofは、変数がオブジェクトのインスタンスであるかどうかを決定するために使用される三項演算子です。この演算子は JavaScript のオブジェクト指向と関係があります。これを理解するには、まず JavaScript のオブジェクト指向を理解する必要があります。この演算子は、オブジェクトのプロトタイプ チェーンがコンストラクターのプロトタイプ オブジェクトを指しているかどうかを検出するためです。


a instanceof b?alert("true"):alert("false") 
//注意b值是你想要判断的那种数据类型,是不是一个字符串,比如Array

例:


var arr = [1,2,3,1]; 
alert(arr instanceof Array); // true

2) W3C 定義のコンストラクター

: コンストラクター プロパティは、このオブジェクト


var arr = []; 
arr instanceof Array; // true 
arr.constructor == Array; //true
を作成した配列関数への参照を返します。

それぞれを判断する最初のタイプのメソッド:


console.log("string".constructor == String);
console.log((123).constructor == Number);
console.log(false.constructor == Boolean);
console.log([].constructor == Array);
console.log({}.constructor == Object);

一般的なメソッド:


function isArray(object){
  return object && typeof object==='object' &&
      Array == object.constructor;
}

3) 特性判定

object.isArray() を使用して、値が正しいかどうかを正確に検出することが目的です。配列。 IE9 以降、Firefox 4 以降、Safari 5 以降、Opera 10.5 以降、および Chrome はすべてこのメソッドを実装しています。ただし、IE8 より前のバージョンはサポートされていません。


function isArray(object){
  return object && typeof object==='object' &&  
      typeof object.length==='number' && 
      typeof object.splice==='function' &&  
       //判断length属性是否是可枚举的 对于数组 将得到false 
      !(object.propertyIsEnumerable('length'));
}

4) Object.prototype.toString.call


Object.prototype.toString.call(value) == '[object Array]'

以上がjsのデータ型と配列メソッドインスタンスの判断方法を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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