Heim  >  Artikel  >  Web-Frontend  >  So erhalten Sie den Typ einer Javascript-Variablen

So erhalten Sie den Typ einer Javascript-Variablen

青灯夜游
青灯夜游Original
2021-10-28 17:47:048363Durchsuche

Methoden zum Abrufen des Typs von JavaScript-Variablen: 1. Verwenden Sie den Typeof-Operator, Syntax „typeof Variable“. 2. Verwenden Sie die „$.type()“-Methode von jQuery. 3. Rufen Sie den Typ über den Konstruktor ab.

So erhalten Sie den Typ einer Javascript-Variablen

Die Betriebsumgebung dieses Tutorials: Windows7-System, Javascript1.8.5 &&jquery1.10.0-Version, Dell G3-Computer.

In JavaScript wird häufig gefragt, wie der Typname einer Variablen genau ermittelt werden kann.

Aber häufig kann der genaue Name der Variablen nicht ermittelt werden, oder es muss die Methode in jQuery verwendet werden .type und Die drei Methoden zur Verwendung von Konstruktoren zum Erhalten von Variablentypen werden ausführlich vorgestellt.

Ich hoffe, es kann Ihnen helfen.

Beim ersten Blick auf die Frage denken einige Schüler möglicherweise an den Typ des Operators.


Verwenden typeof, um den Basistyp zu erhalten.

In der JavaScript-Sprache ist es üblich, den Typof-Operator zu verwenden, um den Basistypnamen zu erhalten. (Beachten Sie, dass es sich nicht um einen Basistyp handelt.)

Dies ist die gesamte Verwendung von typeof

01-typeof.htm

console.log('typeof of 10 ~~~~' +typeof 10);
console.log('typeof of "a" ~~~~' +typeof 'a');
console.log('typeof of true ~~~~' +typeof true);
console.log('typeof of {} ~~~~' +typeof {});
console.log('typeof of /123/ ~~~~' +typeof /123/);
console.log('typeof of function(){} ~~~~' +typeof function(){});
console.log('typeof of undefined ~~~~' +typeof undefined);
console.log('typeof of null ~~~~' +typeof null);

Das ist Ergebnis

Gemäß den oben gedruckten Ergebnissen fassen wir die folgenden zu beachtenden Punkte zusammen:typeof (Referenztyp) Mit Ausnahme von Funktionen sind sie alle „Objekt“. , wie zum Beispiel typeof /123/

  • typeof null ist „Objekt“

  • typeof undefiniert ist „undefiniert“. Wenn Sie zwei Gleichheitszeichen verwenden, ist null == undefiniert normalerweise wahr

  • ist ein Übliche Verwendung der Konvertierung in Zahlen „10“-0. Wenn die Konvertierung nicht erfolgreich ist, wird NaN aufgrund einer Eigenschaft von NaN zurückgegeben: NaN != NaN. Die übliche Methode zur Beurteilung, ob die Konvertierung erfolgreich ist, ist also: (Dies ist Auch das, was ich beim 100-maligen Lesen des jQuery-Quellcodes herausgefunden habe, ist keine Übertreibung)

    ( "10x" - 0) == ("10x" - 0); ist falsch!


  • ("10x" - 0) == ("10x" - 0); // 结果为假!

使用jQuery中的方法$.type()

现在看看jQuery是怎么做的

// 先申明一个对象,目的是用来做映射
var class2type = {};
// 申明一个core_toString() 的方法,得到最原始的toString() 方法,因为在很多对象中,toStrintg() 已经被重写 
var core_toString() = class2type.toString;
// 这里为 toStrintg() 后的结果和类型名做一个映射,申明一个core_toString() 后的结果,而值就是类型名
jQuery.each("Boolean Number String Function Array Date RegExp Object Error".split(" "), function(i, name) {
    class2type[ "[object " + name + "]" ] = name.toLowerCase();
});

因为 Object.prototype.toString() 方法调用结果如下

var core_toString = {}.toString;
console.log( core_toString.call(1) );
console.log( core_toString.call("11") );
console.log( core_toString.call(/123/) );
console.log( core_toString.call({}) );
console.log( core_toString.call(function(){}) );
console.log( core_toString.call([]) );
console.log( core_toString.call(true) );
console.log( core_toString.call(new Date()) );
console.log( core_toString.call(new Error() ));
console.log( core_toString.call(null) );
console.log( core_toString.call(undefined) );
console.log( String(null) );
console.log( String(undefined) );

上面的打印结果与

class2type[ "[object " + name + "]" ] = name.toLowerCase();

不谋而合!

这是jQuery.type 的核心方法

type: function( obj ) {
    if ( obj == null ) {
        return String( obj );
    }
    // Support: Safari <= 5.1 (functionish RegExp)
    return typeof obj === "object" || typeof obj === "function" ?
        class2type[ core_toString.call(obj) ] || "object" :
        typeof obj;
},

注意,为什么把 null 或者 undefined 单独讨论呢,因为 在一些版本浏览器中


console.log(core_toString.call(null));
console.log(core_toString.call(undefined));

这是会报错的!

如果是对象类型,另:由于 在一些低版本的浏览器中,typeof /123/ 会返回的是 "function" 而不是 "object",所以这里要判断是否是函数,要明白 这里的 typeof obj === function Verwenden Sie die Methode $.type()

Jetzt sehen Sie, wie jQuery es macht

typeof obj === "object" || typeof obj === "function" ?
        class2type[ core_toString.call(obj) ]
class2type[ core_toString.call(obj) ] || "object" :
// 这是防止一些未知情况的,如果未取到,就返回object
Weil Object.prototype.toStr ing( ) Das Ergebnis des Methodenaufrufs ist wie folgt
function Person(){
   this.name = &#39;pawn&#39;;
}
var p = Person.toString();

Der obige Druck Das Ergebnis stimmt mit
  function Person(){
      this.name = &#39;pawn&#39;;
  }
  console.log(Person.prototype.constructor === Person);

!

Dies ist die Kernmethode von jQuery.type
  function Person(){
      this.name = &#39;pawn&#39;;
  }
  Person.protype = {
      XX: ... ,
      xx: ... ,
      ...
  }

Beachten Sie, warum null oder undefiniert separat besprochen werden, denn in einigen Browserversionen

  Person.protype = {
      construction: Person,
      XX: ... ,
      xx: ... ,
      ...
  }
Dies wird einen Fehler melden!

Wenn es sich um einen Objekttyp handelt, einen anderen : In einigen Browsern niedrigerer Versionen gibt typeof /123/ „function“ anstelle von „object“ zurück. Um festzustellen, ob es sich um eine Funktion handelt, müssen Sie Folgendes verstehen: typeof obj === function hier wird für Funktionen nicht besprochen, da die Funktion selbst den Typ über typeof erhalten kann.
  jQuery.fn = jQuery.prototype = {
    constructor: jQuery,
    init: function( selector, context, rootjQuery ) {
        var match, elem;
Geben Sie einfach den Schlüsselwert von class2type direkt zurück. Wenn nicht, muss es ein Basistyp sein, übergeben Sie einfach typeof.

   var getType = function(obj){
       if(obj == null){
          return String(obj);
       }
       if(typeof obj === &#39;object&#39; || typeof obj === &#39;fucntion&#39;){
           ...
       }else{
           // 如果不是引用类型,那么就是基本类型
           return typeof obj
       }
   }

Aber

jQuery.type

hat einen großen Fehler

Dies ist ein benutzerdefinierter Typ

   function Person(){
       this.name = &#39;pawn&#39;;
   }
   var p = new Person();
   console.log(p.constructor);

// Hinweis: Mit der oben genannten Methode kann der genaue benutzerdefinierte Typ nicht abgerufen werden. Dies ist auch ein großer Fehler!

Als nächstes erhalten wir den genauen Typ über den Konstruktor

Durch den Konstruktor, um den Typ zu erhalten

Bevor Sie diese Methode verstehen, müssen Sie zwei Punkte verstehen


Prorotyp-Prototypenattribut

  • Wir wissen dass jedes Objekt oder jede Funktion direkt oder indirekt vom Objekt oder der Funktion erbt (tatsächlich wird die Funktion letztendlich vom Objekt geerbt, das zum Wissen der Prototypenkette gehört). Dann hat jedes Objekt ein Prototypobjekt __proto__ (dieses Objekt wird nur in Chrome und Firefox verfügbar gemacht, existiert aber auch in anderen Browsern. Dieses Prototypobjekt ist das Prototypattribut des Konstruktors dieses Objekts (dies kann etwas verwirrend sein).
  • Da jede Funktion über ein Prototypattribut „Prototyp“ verfügt und dieses Prototypattribut über einen Standardattributkonstruktor verfügt, der auf diese Funktion verweist, schauen Sie sich den Code unten an
 var regex = /function\s(.+?)\(/
   function Person(){
    this.name = &#39;pawn&#39;;
   }
   var p = new Person();
   var c = p.constructor
   var regex = /function\s(.+?)\(/;
   console.log(&#39;|&#39; + regex.exec(c)[1] + &#39;|&#39;);

🎜🎜Ich habe festgestellt, dass diese beiden Dinge tatsächlich gleich sind thing🎜🎜 In einigen Fällen müssen Sie jedoch so schreiben 🎜
var getType = function(obj){
    if(obj == null){
        return String(obj);
    }
    if(typeof obj === &#39;object&#39; || typeof obj === &#39;function&#39;){ 
        var constructor = obj.constructor;
        if(constructor && constructor.name){
            return constructor.name;
        }
        var regex = /function\s(.+?)\(/;
        return regex.exec(c)[1];
    }else{
        // 如果不是引用类型,那么就是基本;类型
        return typeof obj;
    }
};
🎜 Dadurch wird die ursprüngliche Prototypmethode überschrieben, und dann ist der Konstruktor nicht mehr vorhanden. Aus diesem Grund müssen Sie dieses Objekt explizit deklarieren🎜
var getType = function(obj){
    if(obj == null){
        return String(obj);
    }
    if(typeof obj === &#39;object&#39; || typeof obj === &#39;function&#39;){ 
        return obj.constructor && obj.constructor.name.toLowerCase() || 
          /function\s(.+?)\(/.exec(obj.constructor)[1].toLowerCase();
    }else{
        // 如果不是引用类型,那么就是基本类型
        return typeof obj;
    }
};
🎜In jQuery , Das ist es, 🎜
var getType = function(obj){
    if(obj == null){
       return String(obj);
    }
    return typeof obj === &#39;object&#39; || typeof obj === &#39;function&#39; ?
      obj.constructor && obj.constructor.name && obj.constructor.name.toLowerCase() ||
          /function\s(.+?)\(/.exec(obj.constructor)[1].toLowerCase():
      typeof obj;
};
🎜🎜Es lohnt sich auch, die Art und Weise der Kapselung von jQuery-Objekten zu studieren🎜🎜🎜🎜🎜Function.prototype.toString()🎜🎜🎜🎜🎜Beachten Sie, dass dies mit [object Object] nicht mehr vertraut ist, aber bereits Umgeschrieben.🎜

也就是,如果调用一个函数的toString() 方法.那么就会打印这个函数的函数体.


好了,经过上面两个步骤,你明白我要做什么了吗?

如何通过构造函数来获得变量的类型?

判断是否是基本类型

   var getType = function(obj){
       if(obj == null){
          return String(obj);
       }
       if(typeof obj === &#39;object&#39; || typeof obj === &#39;fucntion&#39;){
           ...
       }else{
           // 如果不是引用类型,那么就是基本类型
           return typeof obj
       }
   }

如果是对象或者函数类型

   function Person(){
       this.name = &#39;pawn&#39;;
   }
   var p = new Person();
   console.log(p.constructor);

现在要做的事 : 如何将Person 提取出来呢?
毋庸置疑,字符串切割那一套肯定可以办到,但是太 low 啦!
这里,我使用正则将Person提取出来

 var regex = /function\s(.+?)\(/
   function Person(){
    this.name = &#39;pawn&#39;;
   }
   var p = new Person();
   var c = p.constructor
   var regex = /function\s(.+?)\(/;
   console.log(&#39;|&#39; + regex.exec(c)[1] + &#39;|&#39;);

使用name

其实,除了上面的正则,每个函数还有一个name属性,返回函数名,但是ie8 是不支持的.

因此上面的代码可以写为:

var getType = function(obj){
    if(obj == null){
        return String(obj);
    }
    if(typeof obj === &#39;object&#39; || typeof obj === &#39;function&#39;){ 
        var constructor = obj.constructor;
        if(constructor && constructor.name){
            return constructor.name;
        }
        var regex = /function\s(.+?)\(/;
        return regex.exec(c)[1];
    }else{
        // 如果不是引用类型,那么就是基本;类型
        return typeof obj;
    }
};

但是上面的代码太丑啦,将其简化

简化

var getType = function(obj){
    if(obj == null){
        return String(obj);
    }
    if(typeof obj === &#39;object&#39; || typeof obj === &#39;function&#39;){ 
        return obj.constructor && obj.constructor.name.toLowerCase() || 
          /function\s(.+?)\(/.exec(obj.constructor)[1].toLowerCase();
    }else{
        // 如果不是引用类型,那么就是基本类型
        return typeof obj;
    }
};

还是比较麻烦,继续简化

var getType = function(obj){
    if(obj == null){
       return String(obj);
    }
    return typeof obj === &#39;object&#39; || typeof obj === &#39;function&#39; ?
      obj.constructor && obj.constructor.name && obj.constructor.name.toLowerCase() ||
          /function\s(.+?)\(/.exec(obj.constructor)[1].toLowerCase():
      typeof obj;
};

好了,已经全部弄完了,写个代码测试一下:

function Person(){
    this.name = &#39;pawn&#39;;
}
var p = new Person();

console.log(getType(p));
console.log(getType(1));
console.log(getType("a"));
console.log(getType(false));
console.log(getType(/123/));
console.log(getType({}));
console.log(getType(function(){}));
console.log(getType(new Date()));
console.log(getType(new Error()));
console.log(getType( null));
console.log(getType( undefined));

【推荐学习:javascript高级教程

Das obige ist der detaillierte Inhalt vonSo erhalten Sie den Typ einer Javascript-Variablen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn