成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

淺談Object.prototype.toString.call()方法

weakish / 1479人閱讀

摘要:在里使用判斷數(shù)據(jù)類型,只能區(qū)分基本類型,即。對(duì)于來說,使用都會(huì)統(tǒng)一返回字符串。要想?yún)^(qū)分對(duì)象數(shù)組函數(shù)單純使用是不行的。在中,可以通過方法,判斷某個(gè)對(duì)象之屬于哪種內(nèi)置類型。實(shí)例為對(duì)象添加一個(gè)去除重復(fù)項(xiàng)的方法這里要注意,為,為。

在JavaScript里使用typeof判斷數(shù)據(jù)類型,只能區(qū)分基本類型,即:number、string、undefined、boolean、object。
對(duì)于null、array、function、object來說,使用typeof都會(huì)統(tǒng)一返回object字符串。
要想?yún)^(qū)分對(duì)象、數(shù)組、函數(shù)、單純使用typeof是不行的。在JS中,可以通過Object.prototype.toString方法,判斷某個(gè)對(duì)象之屬于哪種內(nèi)置類型。
分為null、string、boolean、number、undefined、array、function、object、date、math。

判斷基本類型

Object.prototype.toString.call(null); // "[object Null]"
Object.prototype.toString.call(undefined); // "[object Undefined]"
Object.prototype.toString.call(“abc”);// "[object String]"
Object.prototype.toString.call(123);// "[object Number]"
Object.prototype.toString.call(true);// "[object Boolean]"

判斷原生引用類型

函數(shù)類型
Function fn(){
console.log(“test”);
}
Object.prototype.toString.call(fn); // "[object Function]"
日期類型
var date = new Date();
Object.prototype.toString.call(date); // "[object Date]"
數(shù)組類型
var arr = [1,2,3];
Object.prototype.toString.call(arr); // "[object Array]"
正則表達(dá)式
var reg = /[hbc]at/gi;
Object.prototype.toString.call(reg); // "[object RegExp]"
自定義類型
function Person(name, age) {

this.name = name;
this.age = age;

}
var person = new Person("Rose", 18);
Object.prototype.toString.call(arr); // "[object Object]"
很明顯這種方法不能準(zhǔn)確判斷person是Person類的實(shí)例,而只能用instanceof 操作符來進(jìn)行判斷,如下所示:

console.log(person instanceof Person); // true

判斷原生JSON對(duì)象

var isNativeJSON = window.JSON && Object.prototype.toString.call(JSON);
console.log(isNativeJSON);// 輸出結(jié)果為”[object JSON]”說明JSON是原生的,否則不是;
注意:Object.prototype.toString()本身是允許被修改的,而我們目前所討論的關(guān)于Object.prototype.toString()這個(gè)方法的應(yīng)用都是假設(shè)toString()方法未被修改為前提的。

實(shí)例:為Array對(duì)象添加一個(gè)去除重復(fù)項(xiàng)的方法

input
[false, true, undefined, null, NaN, 0, 1, {}, {}, "a", "a", NaN].uniq()
output
[false, true, undefined, null, NaN, 0, 1, {}, {}, "a"]
這里要注意,NaN === NaN 為false,{} === {}為false。

Array.prototype.uniq = function () {

if (!this.length || this.length == 0) return this;
var res = [], key, hasNaN = false, temp = {};
for (var i = 0 ; i < this.length; i++) {
    if (typeof this[i] === "object") {
        res.push(this[i]);
    } else if (this[i] != this[i]) { // 如果當(dāng)前遍歷元素是NaN
        if (!hasNaN) {
            res.push(this[i]);
            hasNaN = true;
        }
    } else {
        key = typeof(this[i]) + this[i];
        if (!temp[key]) {
            res.push(this[i]);
            temp[key] = true;
        }
    }
}
return res;

}
另一種解法:

Array.prototype.uniq = function () {

var res = [];
var flag = true;
this.forEach(function(x) {
    if (res.indexOf(x) == -1) {
        if (x != x) {
            if (flag) {
                res.push(x);
                flag = false;
            }
        } else {
            res.push(x);
        }
    }
})
return res;

}
小禮物走一走,

作者:公子七
鏈接:https://www.jianshu.com/p/585...
來源:簡(jiǎn)書
簡(jiǎn)書著作權(quán)歸作者所有,任何形式的轉(zhuǎn)載都請(qǐng)聯(lián)系作者獲得授權(quán)并注明出處。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/96694.html

相關(guān)文章

  • 淺談ES6中基本數(shù)據(jù)類型的操作方法

    摘要:值得注意的是,中整數(shù)和浮點(diǎn)數(shù)采用的是同樣的儲(chǔ)存方法位雙精度浮點(diǎn)數(shù),所以和被視為同一個(gè)值。 在Javascript中,數(shù)據(jù)類型分為基本數(shù)據(jù)類型和引用數(shù)據(jù)類型兩大類,其中,Array和Function在本質(zhì)上仍然是一種特殊的對(duì)象: 基本類型: String / Number / Boolean / Null / Undefined引用類型: Object / Array / Functio...

    longmon 評(píng)論0 收藏0
  • js基礎(chǔ)深入淺出

    摘要:當(dāng)多個(gè)事件觸發(fā)的時(shí)候,會(huì)把異步事件依次的放入里等同步事件執(zhí)行完之后,再去隊(duì)列里一個(gè)個(gè)執(zhí)行拾遺常用方法總結(jié)面試的信心來源于過硬的基礎(chǔ)參考高級(jí)程序設(shè)計(jì)你所不知道的深入淺出知識(shí)點(diǎn)思維導(dǎo)圖經(jīng)典實(shí)例總結(jié)那些剪不斷理還亂的關(guān)系 持續(xù)不斷更新。。。 基本類型和引用類型 vue props | Primitive vs Reference Types 基本類型和字面值之間的區(qū)別 基本類型和字面值相等,...

    phodal 評(píng)論0 收藏0
  • 淺談JS的淺拷貝和深拷貝(遞歸和樹遍歷)

    摘要:對(duì)象的特殊性因?yàn)閷?duì)象的是通過指針仔細(xì)內(nèi)存地址的,所以對(duì)象的拷貝不能像變量一般簡(jiǎn)單的賦值,對(duì)象的賦值只是將指針的地址賦值過去而已,修改屬性值會(huì)對(duì)所有指向這個(gè)內(nèi)存地址的對(duì)象的屬性值都會(huì)被改變,見下面的例子變量賦值修改不會(huì)對(duì)造成影響對(duì)象賦值修改會(huì) 1.對(duì)象的特殊性 因?yàn)閷?duì)象的是通過指針仔細(xì)內(nèi)存地址的,所以對(duì)象的拷貝不能像變量一般簡(jiǎn)單的賦值,對(duì)象的賦值只是將指針的地址賦值過去而已,修改屬性值會(huì)...

    cjie 評(píng)論0 收藏0
  • Object.prototype.toString.call(obj) 與 obj.toStrin

    摘要:判斷一個(gè)變量的類型通常使用這樣的方式也可以去判斷一個(gè)變量的類型,但問題在于不嚴(yán)謹(jǐn)。另外,不直接使用方法的原因,還有一個(gè)就是對(duì)象的方法有可能會(huì)被改寫。 判斷一個(gè)變量的類型 typeof 通常使用 typeof a; 這樣的方式也可以去判斷一個(gè)變量的類型,但問題在于不嚴(yán)謹(jǐn)。比如: typeof null; // object typeof []; // object 但有時(shí)候,...

    bang590 評(píng)論0 收藏0
  • 利用Object.prototype.toString.call()來進(jìn)行類型檢驗(yàn)

    摘要:會(huì)將數(shù)組中的每個(gè)元素一個(gè)個(gè)傳入給。參考鏈接與的區(qū)別二進(jìn)行類型檢驗(yàn)首先來看一個(gè)問題,用來檢驗(yàn)類型有什么缺點(diǎn)呢答案是無法準(zhǔn)確地檢驗(yàn)對(duì)象類型。比較好的方式就是用來進(jìn)行檢驗(yàn)。判斷是否是對(duì)象類型注意使用是不能得到類型的。 一、apply與call的區(qū)別 相同點(diǎn):可以讓一個(gè)對(duì)象調(diào)用另一個(gè)對(duì)象的方法不同點(diǎn): apply最多只能傳入兩個(gè)參數(shù),第一個(gè)為對(duì)象,第二個(gè)為數(shù)組 call能傳入多個(gè)參數(shù),第一個(gè)...

    JackJiang 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<