ホームページ > ウェブフロントエンド > jsチュートリアル > jsのデータ型判定と配列判定について簡単に解説

jsのデータ型判定と配列判定について簡単に解説

高洛峰
リリース: 2017-01-14 10:02:41
オリジナル
1160 人が閲覧しました

冒頭に書きました:

昨日の面接で、とてもとても簡単な質問に答えられなかったのは、緊張しすぎて泣きそうになったからかもしれません。後から思いついたのですが、しっかりと記録して、印象に残るようにしておこうと思いました。革命はまだ成功していない、私たちはまだまだ強くなるために努力する必要があります!

1. js の 6 つの主要なデータ型

数値: 数値、整数、浮動小数点数など、

文字列: 示す単一引用符または二重引用符、

ブール: これら 2 つの値を返します。必ずしも 1 と 0 に対応するわけではありません。

object: オブジェクト。new 演算子の後に作成するオブジェクト タイプの名前を実行することで作成できます。

null: 値のデータ型は 1 つだけです。論理的に、null 値は null オブジェクト ポインターを表します。

未定義: 未定義。変数が var を使用して宣言されているが初期化されていない場合、変数の値は未定義です。

2. データ型判定 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) などの関数が返されます。

3. 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定義におけるconstructor

の定義:constructor属性は、このオブジェクトを作成した配列関数への参照を返す

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 サイトを応援していただければ幸いです。

jsのデータ型判定と配列判定に関するその他の記事は、PHP中国語Webサイトに注目してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート