文章出處
文章列表
我們都知道在js中普通類型的變量是沒有屬性和方法的,然后有時卻并不是這樣。
var str = "努力,奮斗"; console.log(str.length); //5 var num = 10; console.log(typeof num.toString()); //string
為什么會這樣?因為一旦我們在普通類型的變量中使用了屬性或者方法,js就會自動new一個對應的對象。
var str = "努力,奮斗"; console.log(str = new String("努力,奮斗").length);
會將變量的內容添加到對象的第一個參數中,其實這個這個創建的過程就叫做包裝對象,new String就是str的包裝對象。但是值得注意的是這個包裝對象一旦運行以后就會銷毀。
var str = "努力,奮斗"; str.index = 10; str.fn = function(){ console.log(str); } console.log(str.index); //undefined str.fn(); //報錯
可以更簡單的理解,就是這些基本類型只能使用包裝對象的提供的屬性和方法,而不能自定義屬性和方法。
文章列表
全站熱搜