首頁 >web前端 >js教程 >JS的clone()函數如何使用

JS的clone()函數如何使用

php中世界最好的语言
php中世界最好的语言原創
2018-03-20 09:58:536069瀏覽

這次帶給大家JS的clone()函數如何使用,使用JS的clone()函數注意事項有哪些,以下就是實戰案例,一起來看一下。

一、解題程式碼

直接貼程式碼,

function clone(obj){            var copy;            switch(typeof obj){                case 'undefined':break;                case 'number':                case 'string':                case 'boolean':                case 'function':copy = obj;break;                case 'object':                    if(obj == null) copy = null;                    else if(toString.call(obj) === '[object Array]')
                    {
                        copy = [];                        for(var i in obj) copy.push(clone(obj[i]));
                    }                    else if(toString.call(obj) === '[object RegExp]')
                    {
                        copy = obj;
                    }                    else 
                    {
                        copy = {};                        for(var j in obj)
                            copy[j]= clone(obj[j]);
                    }
            }            return copy;
        }        var a=undefined;        var b=1;        var c="Hello";        var d=true;        var add=function(a,b){            return a+b;
        }        var e=null;        var f=[1,2,3];        var g=/^\s+/;        var h={
            a:1,
            b:2
        }
        console.log(typeof clone(a));
        console.log(typeof clone(b));
        console.log(typeof clone(c));
        console.log(typeof clone(d));
        console.log(clone(add)(1,2));
        console.log(Object.prototype.toString.call(clone(e)));
        console.log(Object.prototype.toString.call(clone(f)));
        console.log(Object.prototype.toString.call(clone(g)));
        console.log(Object.prototype.toString.call(clone(h)));

結果:

二、疑問

一開始看到這個問題的時候,就想到typeof [1,2,3]的結果是,這可怎麼辦,正則表達式,null, object的typeof都是。看上面的程式碼,是用Object.prototype.toString.call(obj)或toString.call(obj)來解決的。

那為什麼不直接用obj.toString()呢?我們先來看看obj.toString()會輸出什麼?

null和undefined居然出錯了,這是肯定的,因為toString()不可完成null和undefined的轉型,用String()才可以

若String()轉換的不是null或undefined,則自動轉換為toString().扯遠了。 。我們說回正題

那麼用Object.prototype.toString.call(obj)的結果是什麼呢?

居然不一樣,這是怎麼回事?

原來,雖然Array,Null等型別雖然是Object的實例,但是他們各自都重寫了toString()方法,我們試著來驗證一下:

var arr=[1,2,3];
console.log(Array.prototype.hasOwnProperty("toString"));//判断原型中是否有toString()方法console.log(arr.toString());delete Array.prototype.toString;//删除Array原型里面重写的toStringconsole.log(Array.prototype.hasOwnProperty("toString"));
console.log(arr.toString());

結果:

很明顯真的被改寫了。

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

text-align如何實現兩端對齊

Mac系統裡MySQL重設Root密碼


以上是JS的clone()函數如何使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn