熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> Java編程 >> JSP教程 >> 正文

javascript之typeof、instanceof操作符使用

2013-11-15 11:56:11  來源: JSP教程 

  寫javascirpt代碼時typeof和instanceof這兩個操作符時不時就會用到堪稱必用但是!使用它們總是不能直接的得到想要的結果非常糾結普遍的說法認為“這兩個操作符或許是javascript中最大的設計缺陷因為幾乎不可能從他們那裡得到想要的結果”

  typeof

  說明typeof返回一個表達式的數據類型的字符串返回結果為js基本的數據類型包括numberbooleanstringobjectundefinedfunction

  從說明來看貌似沒什麼問題

  下面的代碼寫了一個數值變量typeof後的結果是"number"

  代碼如下:

  var a = ;

  consolelog(typeof(a)); //=>number

  如果用Number類型的構造函數new一個變量的話typeof後的結果是"object"

  復制代碼 代碼如下:

  var a = new Number();

  consolelog(typeof(a)); //=>object

  上面的這兩個輸出結果看似沒啥問題這一點從書上看來是理所當然的事情因為javascript就是這麼設計的

  但是!問題就在於既然調用了typeof就應該准確返回一個變量的類型不管是直接用值創建的還是用類型的構造函數創建的否則!我還用你做啥!

  那麼對於

  代碼如下:

  var a = ;

  var b = new Number();

  a和b變量的類型准確的說來都應該是Number才是想要的結果

  而准確的類型信息保存在變量的內部屬性 [[Class]] 的值中通過使用定義在 Objectprototype 上的方法 toString來獲取

  獲取類型信息

  代碼如下:

  var a = ;

  var b = new Number();

  consolelog(ObjectprototypetoStringcall(a));

  consolelog(ObjectprototypetoStringcall(b));

  輸出

  代碼如下:

  [object Number]

  [object Number]

  是不是已經很直接了我們稍微處理一下得到直接結果

  代碼如下:

  var a = ;

  var b = new Number();

  consolelog(ObjectprototypetoStringcall(a)slice());

  consolelog(ObjectprototypetoStringcall(b)slice());

  輸出

  Number

  Number

  這就是想要的結果

  為了更好的使用我們封裝一個方法用來判斷某個變量是否是某種類型:

  代碼如下:

  function is(objtype) {

  var clas = ObjectprototypetoStringcall(obj)slice( );

  return obj !== undefined && obj !== null && clas === type;

  }

  定義一些變量做過測試先來看看它們的typeof輸出

  代碼如下:

  var a=;

  var a=Number();

  var b="hello";

  var b=new String("hello");

  var c=[];

  var c=new Array();

  consolelog("as typeof:"+typeof(a));

  consolelog("as typeof:"+typeof(a));

  consolelog("bs typeof:"+typeof(b));

  consolelog("bs typeof:"+typeof(b));

  consolelog("cs typeof:"+typeof(c));

  consolelog("cs typeof:"+typeof(c));

  輸出

  as typeof:number

  as typeof:object

  bs typeof:string

  bs typeof:object

  cs typeof:object

  cs typeof:object

  我們再用新作的函數是一下

  代碼如下:

  consolelog("a is Number:"+is(a"Number"));

  consolelog("a is Number:"+is(a"Number"));

  consolelog("b is String:"+is(b"String"));

  consolelog("b is String:"+is(b"String"));

  consolelog("c is Array:"+is(c"Array"));

  consolelog("c is Array:"+is(c"Array"));

  輸出

  a is Number:true

  a is Number:true

  b is String:true

  b is String:true

  c is Array:true

  c is Array:true

  注typeof也不是無用實際用處是用來檢測一個變量是否已經定義或者是否已經賦值

  instanceof

  說明判斷一個對象是否為某一數據類型或一個變量是否為一個對象的實例

  instanceof 操作符用來比較兩個內置類型的變量時一樣力不從心同樣會對結果不滿意

  代碼如下:

  consolelog("abc" instanceof String); // false

  consolelog("abc" instanceof Object); // false

  consolelog(new String("abc") instanceof String); // true

  consolelog(new String("abc") instanceof Object); // true

  只有在比較自定義的對象時才准確反映關系

  代碼如下:

  function Person() {}

  function Man() {}

  Manprototype = new Person();

  consolelog(new Man() instanceof Man); // true

  consolelog(new Man() instanceof Person); // true


From:http://tw.wingwit.com/Article/program/Java/JSP/201311/19924.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.