亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javascript之typeof、instanceof操作符使用探討

2019-11-20 22:42:30
字體:
來源:轉載
供稿:網友
寫javascirpt代碼時,typeof和instanceof這兩個操作符時不時就會用到,堪稱必用。但是!使用它們總是不能直接的得到想要的結果,非常糾結,普遍的說法認為“這兩個操作符或許是javascript中最大的設計缺陷,因為幾乎不可能從他們那里得到想要的結果”
typeof
說明:typeof返回一個表達式的數據類型的字符串,返回結果為js基本的數據類型,包括number,boolean,string,object,undefined,function。
從說明來看,貌似沒什么問題。

下面的代碼寫了一個數值變量,typeof后的結果是"number"。
復制代碼 代碼如下:

var a = 1;
console.log(typeof(a)); //=>number

如果用Number類型的構造函數new一個變量的話,typeof后的結果是"object"。
復制代碼 代碼如下:

var a = new Number(1);
console.log(typeof(a)); //=>object

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

但是!問題就在于既然調用了typeof就應該準確返回一個變量的類型,不管是直接用值創建的還是用類型的構造函數創建的,否則!我還用你做啥!
那么對于:
復制代碼 代碼如下:

var a = 1;
var b = new Number(1);

a和b變量的類型準確的說來都應該是Number才是想要的結果。
而準確的類型信息保存在變量的內部屬性 [[Class]] 的值中,通過使用定義在 Object.prototype 上的方法 toString來獲取。

獲取類型信息:
復制代碼 代碼如下:

var a = 1;
var b = new Number(1);
console.log(Object.prototype.toString.call(a));
console.log(Object.prototype.toString.call(b));

輸出:
復制代碼 代碼如下:

[object Number]
[object Number]

是不是已經很直接了,我們稍微處理一下,得到直接結果:
復制代碼 代碼如下:

var a = 1;
var b = new Number(1);
console.log(Object.prototype.toString.call(a).slice(8,-1));
console.log(Object.prototype.toString.call(b).slice(8,-1));

輸出:
Number
Number
這就是想要的結果。
為了更好的使用,我們封裝一個方法,用來判斷某個變量是否是某種類型:
復制代碼 代碼如下:

function is(obj,type) {
var clas = Object.prototype.toString.call(obj).slice(8, -1);
return obj !== undefined && obj !== null && clas === type;
}

定義一些變量做過測試,先來看看它們的typeof輸出:
復制代碼 代碼如下:

var a1=1;
var a2=Number(1);
var b1="hello";
var b2=new String("hello");
var c1=[1,2,3];
var c2=new Array(1,2,3);
console.log("a1's typeof:"+typeof(a1));
console.log("a2's typeof:"+typeof(a2));
console.log("b1's typeof:"+typeof(b1));
console.log("b2's typeof:"+typeof(b2));
console.log("c1's typeof:"+typeof(c1));
console.log("c2's typeof:"+typeof(c2));
輸出:
a1's typeof:number
a2's typeof:object
b1's typeof:string
b2's typeof:object
c1's typeof:object
c2's typeof:object

我們再用新作的函數是一下:
復制代碼 代碼如下:

console.log("a1 is Number:"+is(a1,"Number"));
console.log("a2 is Number:"+is(a2,"Number"));
console.log("b1 is String:"+is(b1,"String"));
console.log("b2 is String:"+is(b2,"String"));
console.log("c1 is Array:"+is(c1,"Array"));
console.log("c2 is Array:"+is(c2,"Array"));
輸出:
a1 is Number:true
a2 is Number:true
b1 is String:true
b2 is String:true
c1 is Array:true
c2 is Array:true

注:typeof也不是無用,實際用處是用來檢測一個變量是否已經定義或者是否已經賦值。
instanceof
說明:判斷一個對象是否為某一數據類型,或一個變量是否為一個對象的實例。
instanceof 操作符用來比較兩個內置類型的變量時一樣力不從心,同樣會對結果不滿意。
復制代碼 代碼如下:

console.log("abc" instanceof String); // false
console.log("abc" instanceof Object); // false
console.log(new String("abc") instanceof String); // true
console.log(new String("abc") instanceof Object); // true

只有在比較自定義的對象時才準確反映關系。
復制代碼 代碼如下:

function Person() {}
function Man() {}
Man.prototype = new Person();
console.log(new Man() instanceof Man); // true
console.log(new Man() instanceof Person); // true
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久噜噜噜久久中文字免| 国内成人精品一区| 日韩视频第一页| 国产一区二区三区丝袜| 性欧美视频videos6一9| 成人激情av在线| 国产日产欧美精品| 中文字幕欧美精品在线| 亚洲成人黄色网址| 高清亚洲成在人网站天堂| 一区二区成人精品| 欧美在线免费观看| 欧美国产第一页| 91精品久久久久久久久久久| 国产成人福利夜色影视| 国产日韩欧美一二三区| 久久久久久久久国产精品| 中文.日本.精品| 亚洲乱码国产乱码精品精| 国产成人精品最新| 91啪国产在线| 久久久免费高清电视剧观看| 九九热精品视频国产| 亚洲精品动漫100p| 亚洲人精品午夜在线观看| 日韩人在线观看| 欧美一级黑人aaaaaaa做受| 欧美老女人www| 亚洲成人亚洲激情| 欧美在线精品免播放器视频| 成人在线视频网站| 国产成人免费av| 久久精品国产v日韩v亚洲| 国产精品第三页| 欧美精品成人在线| 日韩av电影中文字幕| 欧美一级电影久久| 在线观看国产精品淫| 4k岛国日韩精品**专区| 全色精品综合影院| 黄色成人在线免费| 国产精品国产三级国产aⅴ浪潮| 国产一区二区视频在线观看| 欧美高跟鞋交xxxxhd| 欧美日韩国产影院| y97精品国产97久久久久久| 亚洲日韩欧美视频一区| 亚洲国产另类久久精品| 亚洲色图35p| 国产91成人在在线播放| 国产精品日韩在线观看| 亚洲有声小说3d| 久久精品国产精品| 国产成人av网址| 日韩免费黄色av| 免费91麻豆精品国产自产在线观看| 在线免费观看羞羞视频一区二区| 日韩网站免费观看高清| 亚洲**2019国产| 色综合天天综合网国产成人网| 福利视频一区二区| 亚洲精品福利视频| 欧美成人精品在线视频| 亚洲自拍av在线| 欧美老女人在线视频| 欧美性猛交xxxx黑人猛交| 久久精品国产清自在天天线| 一区二区av在线| 亚洲一区二区久久久久久| 26uuu亚洲伊人春色| 最好看的2019年中文视频| 55夜色66夜色国产精品视频| 欧美日韩一区二区三区| 日韩欧中文字幕| 色小说视频一区| 亚洲人午夜色婷婷| 91久热免费在线视频| 久久综合久久八八| 国产日韩在线亚洲字幕中文| 富二代精品短视频| 欧美一级片久久久久久久| 欧美高跟鞋交xxxxhd| 97欧美精品一区二区三区| 欧美激情久久久| 久久久精品久久久| 欧美日韩亚洲系列| 成人h片在线播放免费网站| 国产精品福利小视频| 日韩电影第一页| 欧美一区二区三区图| 欧美日韩综合视频| 日本免费久久高清视频| 综合136福利视频在线| 午夜美女久久久久爽久久| 日韩福利伦理影院免费| 日韩av观看网址| 国产成人精品亚洲精品| 国产精品久久久久久久7电影| 国产成人精品电影| 国产精品ⅴa在线观看h| 成人福利网站在线观看| 亚洲电影免费观看高清完整版| 亚洲黄色av女优在线观看| 国产精品激情av电影在线观看| 成人午夜在线影院| 国产+人+亚洲| 性色av一区二区咪爱| 亚洲精品720p| 亚洲女同性videos| 爱福利视频一区| 欧美激情精品久久久久久大尺度| 久久99久久99精品免观看粉嫩| 在线视频欧美日韩精品| 亚洲国产精彩中文乱码av| 欧洲美女免费图片一区| 69久久夜色精品国产69| 伊人亚洲福利一区二区三区| 国产一区视频在线播放| 日韩欧美国产成人| 国产欧美中文字幕| 欧美日韩国产一区二区| 国产成一区二区| 欧美激情一二区| 亚洲人成网站777色婷婷| 裸体女人亚洲精品一区| 国产经典一区二区| 国产精品亚洲视频在线观看| 欧美一级bbbbb性bbbb喷潮片| 富二代精品短视频| 亚洲大胆美女视频| 美女撒尿一区二区三区| 狠狠躁夜夜躁久久躁别揉| 欧美大片欧美激情性色a∨久久| 久久五月天色综合| 国产剧情日韩欧美| 精品激情国产视频| 亚洲一二在线观看| 久久久久一本一区二区青青蜜月| 97色在线视频| 国产午夜精品视频免费不卡69堂| 国产精品www色诱视频| 久久久av网站| 亚洲欧美日韩中文在线| 国外成人在线播放| 久久久噜久噜久久综合| 欧美日韩国产成人高清视频| 国产精品96久久久久久| 中文字幕欧美精品日韩中文字幕| 超碰精品一区二区三区乱码| 亚洲图中文字幕| 亚洲激情在线观看| 亚洲精品视频播放| 国产亚洲欧美日韩一区二区| 中国china体内裑精亚洲片| 精品国产欧美成人夜夜嗨| 亚洲一区免费网站| 亚洲夜晚福利在线观看| 亚洲美女福利视频网站| 欧美在线视频一二三| 亚洲aⅴ日韩av电影在线观看| 亚洲精品动漫久久久久| 97视频国产在线| 成人av.网址在线网站| 青草成人免费视频|