《JavaScript高級程序設計》閱讀筆記(三) ECMAScript中的引用類型
更新時間:2012年02月27日 23:30:44 作者:
ECMAScript中的引用類型,主要包括Object類、Boolean類、Number類、String類、instanceof運算符
2.8 引用類型
1、Object類
ECMAScript中的所有類都是由Object類繼承而來。
Object類具有下列屬性:
Constructor:對創(chuàng)建對象的函數(shù)的引用(指針),對于Object類,該指針指向原始的Object()函數(shù)
Prototype:對該對象的對象原型的引用。
Object類還有幾個方法:
HasOwnProperty(property):判斷對象是否有某個特定的屬性。必須用字符串指定該屬性值
IsPrototypeOf(object):判斷該對象是否為另一個對象的原型。
PropertyIsEnumerable(property):判斷給定的屬性是否可以用for...in語句進行枚舉
ToString():返回對象的原始字符串表示。
ValueOf():返回最適合該對象的原始值。對于許多類,該方法返回的值都與toString()的返回值相同。
上面列出的每種屬性和方法都會被其他類覆蓋。
2、Boolean類
在ECMAScript中很少使用Boolean對象,因為不易理解,如:
var oFalseObject = new Boolean(false);
var bResult= oFalseObject && true; //outpus true
在這段代碼中,用false值創(chuàng)建Boolean對象,然后用這個值與原始值true進行 AND 操作。在Boolean運算中,false和true進行AND 操作的結果是 false。不過,在這行代碼中,計算的是oFalseObject,而不是它的值false。在Boolean表達式中,所有對象都會被自動轉換為true,所以結果為true。參考下面的代碼:
var oFalseObject = new Boolean(false);
var bResult= oFalseObject && true; //outpus true
var bResult2= oFalseObject.valueOf() && true; //outpus false
3、Number類
Number的toString()方法在上篇文章中有詳細的介紹。
Number有幾個處理數(shù)值的專用方法:
toFixed(參數(shù)):返回的是具有指定位數(shù)小數(shù)的數(shù)字的字符串表示。參數(shù)范圍為0—20
toExponential(參數(shù)):返回的是用科學計數(shù)法表示的數(shù)字的字符串形式。與toFixed()方法相似,toExponential()也有一個參數(shù)要輸出的小數(shù)的位數(shù)。參數(shù)范圍為0—20
toPrecision(參數(shù)):根據(jù)最有意義的形式來返回數(shù)字的預定形式或指數(shù)形式。它有一個參數(shù),即用于表示數(shù)字總數(shù)(不包括指數(shù))。參數(shù)最小為1
以上三個方法都會進行舍入操作。示例代碼:
var oNumber=new Number(99);
console.log(oNumber.toFixed(0)); //outpus 99
console.log(oNumber.toFixed(2)); //outpus 99.00
var oNumber1=new Number(99);
console.log(oNumber1.toExponential(0)); //outpus 1e+2 進行了舍入操作
console.log(oNumber1.toExponential(1)); //outpus 9.9e+1
console.log(oNumber1.toExponential(2)); //outpus 9.90e+1
var oNumber3=new Number(99);
console.log(oNumber3.toPrecision(0)); //outpus error precision 0 out of range
console.log(oNumber3.toPrecision(1)); //outpus 1e+2 進行了舍入操作
console.log(oNumber3.toPrecision(2)); //outpus 99
console.log(oNumber3.toPrecision(3)); //outpus 99.0
4、String類
String對象的valueOf()方法和toString()方法都會返回String型的原始值:
var oStringObject=new String("Hello world");
console.log(oStringObject.valueOf() == oStringObject.toString());//outpus true
String類具有l(wèi)ength屬性,它是字符串中的字符個數(shù),雙字節(jié)字符也算一個字符。
String類有大量的方法,主要介紹如下:
charAt(整型參數(shù)):返回字符串中單個字符。示例:
var oStringObject=new String("Hello world");
console.log(oStringObject.charAt(0));//outpus "H"
console.log(oStringObject.charAt(1));//outpus "e"
console.log(oStringObject.charAt(11));//outpus (an empty string)
charCodeAt(整型參數(shù)):返回字符串中單個字符代碼。示例:
var oStringObject=new String("Hello world");
console.log(oStringObject.charCodeAt(0));//outpus "72"
console.log(oStringObject.charCodeAt(1));//outpus "101"
console.log(oStringObject.charCodeAt(11));//outpus NaN
concat(字符串):把一個或多個字符串連接到String對象的原始值上。示例:
var oStringObject=new String("Hello world");
var sResult=oStringObject.concat(" Concat");
console.log(oStringObject);//outpus "String { 0="H", 1="e", 2="l", ...}"
console.log(sResult);//outpus "Hello world Concat"
alert(oStringObject);//outpus "Hello world"
indexOf(字符串):返回指定的字符串在另一個字符串中的位置(從字符串的開頭進行檢索)。
lastIndexOf(字符串):返回指定的字符串在另一個字符串中的位置(從字符串的結尾進行檢索)。示例:
var oStringObject=new String("Hello Hello");
console.log(oStringObject.indexOf("lo"));//outpus 3
console.log(oStringObject.lastIndexOf("lo"));//outpus 9
localeCompare(字符串):對字符串進行排序,返回值是下列三個之一:
A、如果String對象按照字母順序排在參數(shù)中的字符串之前,返回負數(shù)(通常是-1,但真正返回值由具體實現(xiàn)決定)
B、如果String對象等于參數(shù)中的字符串,返回0
C、如果String對象按照字母順序排在參數(shù)中的字符串之后,返回正數(shù)(通常是1,但真正返回值由具體實現(xiàn)決定)
示例:
var oStringObject=new String("Hello");
console.log(oStringObject.localeCompare("aello")); //outpus 1
console.log(oStringObject.localeCompare("Hello")); //outpus 0
console.log(oStringObject.localeCompare("zello")); //outpus -1
slice(整型參數(shù)[,整型參數(shù)])、substring(整型參數(shù)[,整型參數(shù)]):從子串創(chuàng)建字符串值。第一個參數(shù)是要獲取的子串的起始位置,第二個參數(shù)是要獲取的子串終止前的位置,如果省略第二參數(shù),終止位就默認為字符串長度。這兩個方法都不改變String對象自身值。當參數(shù)為正時兩個方法用法及返回值均相同,只有參數(shù)有負值時才不同。對于負參數(shù),slice()方法會用字符串的長度加上參數(shù),substring()將其做為0處理。另外如果有兩個參數(shù),第二個比第一個小時,slice()返回的值為空,substring()會把較小的作為第一個參數(shù)。為示例:
var oStringObject=new String("Hello World");
console.log(oStringObject.slice(3)); //outpus "lo World"
console.log(oStringObject.substring(3)); //outpus "lo World"
console.log(oStringObject.slice(3,7)); //outpus "lo W"
console.log(oStringObject.substring(3,7)); //outpus "lo W"
console.log(oStringObject.slice(3,0)); //outpus (an empty string)
console.log(oStringObject.substring(3,0)); //outpus "Hel"
console.log(oStringObject.slice(-3)); //outpus "rld"
console.log(oStringObject.substring(-3)); //outpus "Hello World"
console.log(oStringObject.slice(3,-4)); //outpus "lo W"
console.log(oStringObject.substring(3,-4)); //outpus "Hel"
toLowerCase()、toLocaleLowerCase()、toUpperCase()、toLocaleUpperCase():前兩個用于把字符串轉換為全小寫,后兩個用于把字符串轉換為全大寫。toLowerCase()跟toUpperCase()是原始方法,toLocaleLowerCase()跟toLocaleUpperCase()是基于特定區(qū)域實現(xiàn)的。示例:
var oStringObject=new String("Hello World");
console.log(oStringObject.toLowerCase()); //outpus "hello world"
console.log(oStringObject.toLocaleLowerCase()); //outpus "hello world"
console.log(oStringObject.toUpperCase()); //outpus "HELLO WORLD"
console.log(oStringObject.toLocaleUpperCase()); //outpus "HELLO WORLD"
5、instanceof運算符
在使用typeof運算符時采用引用類型存儲值會出現(xiàn)一個問題,無論引用的是什么類型的對象,它都返回"object"。ECMAScript引入了另一個運算符 instanceof 來解決這個問題。
instanceof運算符與typeof運算符相似,用于識別正在處理的對象的類型。與typeof方法不同的是,instanceof 方法要求開發(fā)者明確地確認對象為某特定類型。示例:
var oStringObject=new String("hello world");
alert(oStringObject instanceof String); //outpus "true"
1、Object類
ECMAScript中的所有類都是由Object類繼承而來。
Object類具有下列屬性:
Constructor:對創(chuàng)建對象的函數(shù)的引用(指針),對于Object類,該指針指向原始的Object()函數(shù)
Prototype:對該對象的對象原型的引用。
Object類還有幾個方法:
HasOwnProperty(property):判斷對象是否有某個特定的屬性。必須用字符串指定該屬性值
IsPrototypeOf(object):判斷該對象是否為另一個對象的原型。
PropertyIsEnumerable(property):判斷給定的屬性是否可以用for...in語句進行枚舉
ToString():返回對象的原始字符串表示。
ValueOf():返回最適合該對象的原始值。對于許多類,該方法返回的值都與toString()的返回值相同。
上面列出的每種屬性和方法都會被其他類覆蓋。
2、Boolean類
在ECMAScript中很少使用Boolean對象,因為不易理解,如:
復制代碼 代碼如下:
var oFalseObject = new Boolean(false);
var bResult= oFalseObject && true; //outpus true
在這段代碼中,用false值創(chuàng)建Boolean對象,然后用這個值與原始值true進行 AND 操作。在Boolean運算中,false和true進行AND 操作的結果是 false。不過,在這行代碼中,計算的是oFalseObject,而不是它的值false。在Boolean表達式中,所有對象都會被自動轉換為true,所以結果為true。參考下面的代碼:
復制代碼 代碼如下:
var oFalseObject = new Boolean(false);
var bResult= oFalseObject && true; //outpus true
var bResult2= oFalseObject.valueOf() && true; //outpus false
3、Number類
Number的toString()方法在上篇文章中有詳細的介紹。
Number有幾個處理數(shù)值的專用方法:
toFixed(參數(shù)):返回的是具有指定位數(shù)小數(shù)的數(shù)字的字符串表示。參數(shù)范圍為0—20
toExponential(參數(shù)):返回的是用科學計數(shù)法表示的數(shù)字的字符串形式。與toFixed()方法相似,toExponential()也有一個參數(shù)要輸出的小數(shù)的位數(shù)。參數(shù)范圍為0—20
toPrecision(參數(shù)):根據(jù)最有意義的形式來返回數(shù)字的預定形式或指數(shù)形式。它有一個參數(shù),即用于表示數(shù)字總數(shù)(不包括指數(shù))。參數(shù)最小為1
以上三個方法都會進行舍入操作。示例代碼:
復制代碼 代碼如下:
var oNumber=new Number(99);
console.log(oNumber.toFixed(0)); //outpus 99
console.log(oNumber.toFixed(2)); //outpus 99.00
var oNumber1=new Number(99);
console.log(oNumber1.toExponential(0)); //outpus 1e+2 進行了舍入操作
console.log(oNumber1.toExponential(1)); //outpus 9.9e+1
console.log(oNumber1.toExponential(2)); //outpus 9.90e+1
var oNumber3=new Number(99);
console.log(oNumber3.toPrecision(0)); //outpus error precision 0 out of range
console.log(oNumber3.toPrecision(1)); //outpus 1e+2 進行了舍入操作
console.log(oNumber3.toPrecision(2)); //outpus 99
console.log(oNumber3.toPrecision(3)); //outpus 99.0
4、String類
String對象的valueOf()方法和toString()方法都會返回String型的原始值:
復制代碼 代碼如下:
var oStringObject=new String("Hello world");
console.log(oStringObject.valueOf() == oStringObject.toString());//outpus true
String類具有l(wèi)ength屬性,它是字符串中的字符個數(shù),雙字節(jié)字符也算一個字符。
String類有大量的方法,主要介紹如下:
charAt(整型參數(shù)):返回字符串中單個字符。示例:
復制代碼 代碼如下:
var oStringObject=new String("Hello world");
console.log(oStringObject.charAt(0));//outpus "H"
console.log(oStringObject.charAt(1));//outpus "e"
console.log(oStringObject.charAt(11));//outpus (an empty string)
charCodeAt(整型參數(shù)):返回字符串中單個字符代碼。示例:
復制代碼 代碼如下:
var oStringObject=new String("Hello world");
console.log(oStringObject.charCodeAt(0));//outpus "72"
console.log(oStringObject.charCodeAt(1));//outpus "101"
console.log(oStringObject.charCodeAt(11));//outpus NaN
concat(字符串):把一個或多個字符串連接到String對象的原始值上。示例:
復制代碼 代碼如下:
var oStringObject=new String("Hello world");
var sResult=oStringObject.concat(" Concat");
console.log(oStringObject);//outpus "String { 0="H", 1="e", 2="l", ...}"
console.log(sResult);//outpus "Hello world Concat"
alert(oStringObject);//outpus "Hello world"
indexOf(字符串):返回指定的字符串在另一個字符串中的位置(從字符串的開頭進行檢索)。
lastIndexOf(字符串):返回指定的字符串在另一個字符串中的位置(從字符串的結尾進行檢索)。示例:
復制代碼 代碼如下:
var oStringObject=new String("Hello Hello");
console.log(oStringObject.indexOf("lo"));//outpus 3
console.log(oStringObject.lastIndexOf("lo"));//outpus 9
localeCompare(字符串):對字符串進行排序,返回值是下列三個之一:
A、如果String對象按照字母順序排在參數(shù)中的字符串之前,返回負數(shù)(通常是-1,但真正返回值由具體實現(xiàn)決定)
B、如果String對象等于參數(shù)中的字符串,返回0
C、如果String對象按照字母順序排在參數(shù)中的字符串之后,返回正數(shù)(通常是1,但真正返回值由具體實現(xiàn)決定)
示例:
復制代碼 代碼如下:
var oStringObject=new String("Hello");
console.log(oStringObject.localeCompare("aello")); //outpus 1
console.log(oStringObject.localeCompare("Hello")); //outpus 0
console.log(oStringObject.localeCompare("zello")); //outpus -1
slice(整型參數(shù)[,整型參數(shù)])、substring(整型參數(shù)[,整型參數(shù)]):從子串創(chuàng)建字符串值。第一個參數(shù)是要獲取的子串的起始位置,第二個參數(shù)是要獲取的子串終止前的位置,如果省略第二參數(shù),終止位就默認為字符串長度。這兩個方法都不改變String對象自身值。當參數(shù)為正時兩個方法用法及返回值均相同,只有參數(shù)有負值時才不同。對于負參數(shù),slice()方法會用字符串的長度加上參數(shù),substring()將其做為0處理。另外如果有兩個參數(shù),第二個比第一個小時,slice()返回的值為空,substring()會把較小的作為第一個參數(shù)。為示例:
復制代碼 代碼如下:
var oStringObject=new String("Hello World");
console.log(oStringObject.slice(3)); //outpus "lo World"
console.log(oStringObject.substring(3)); //outpus "lo World"
console.log(oStringObject.slice(3,7)); //outpus "lo W"
console.log(oStringObject.substring(3,7)); //outpus "lo W"
console.log(oStringObject.slice(3,0)); //outpus (an empty string)
console.log(oStringObject.substring(3,0)); //outpus "Hel"
console.log(oStringObject.slice(-3)); //outpus "rld"
console.log(oStringObject.substring(-3)); //outpus "Hello World"
console.log(oStringObject.slice(3,-4)); //outpus "lo W"
console.log(oStringObject.substring(3,-4)); //outpus "Hel"
toLowerCase()、toLocaleLowerCase()、toUpperCase()、toLocaleUpperCase():前兩個用于把字符串轉換為全小寫,后兩個用于把字符串轉換為全大寫。toLowerCase()跟toUpperCase()是原始方法,toLocaleLowerCase()跟toLocaleUpperCase()是基于特定區(qū)域實現(xiàn)的。示例:
復制代碼 代碼如下:
var oStringObject=new String("Hello World");
console.log(oStringObject.toLowerCase()); //outpus "hello world"
console.log(oStringObject.toLocaleLowerCase()); //outpus "hello world"
console.log(oStringObject.toUpperCase()); //outpus "HELLO WORLD"
console.log(oStringObject.toLocaleUpperCase()); //outpus "HELLO WORLD"
5、instanceof運算符
在使用typeof運算符時采用引用類型存儲值會出現(xiàn)一個問題,無論引用的是什么類型的對象,它都返回"object"。ECMAScript引入了另一個運算符 instanceof 來解決這個問題。
instanceof運算符與typeof運算符相似,用于識別正在處理的對象的類型。與typeof方法不同的是,instanceof 方法要求開發(fā)者明確地確認對象為某特定類型。示例:
復制代碼 代碼如下:
var oStringObject=new String("hello world");
alert(oStringObject instanceof String); //outpus "true"
您可能感興趣的文章:
- JavaScript ECMA-262-3 深入解析(一):執(zhí)行上下文實例分析
- JavaScript高級程序設計 閱讀筆記(七) ECMAScript中的語句
- JavaScript高級程序設計閱讀筆記(六) ECMAScript中的運算符(二)
- JavaScript高級程序設計閱讀筆記(五) ECMAScript中的運算符(一)
- JavaScript高級程序設計 閱讀筆記(四) ECMAScript中的類型轉換
- 《JavaScript高級程序設計》閱讀筆記(二) ECMAScript中的原始類型
- 《JavaScript高級程序設計》閱讀筆記(一) ECMAScript基礎
- JavaScript ECMA-262-3 深入解析.第三章.this
- JavaScript ECMA-262-3 深入解析(二):變量對象實例詳解
相關文章
在javascript中執(zhí)行任意html代碼的方法示例解讀
關于javascript的eval()函數(shù)無法執(zhí)行html代碼的問題,下面為大家介紹下一種在javascript中執(zhí)行任意html代碼的方法,感興趣的朋友不要錯過2013-12-12JS自定義對象實現(xiàn)Java中Map對象功能的方法
這篇文章主要介紹了JS自定義對象實現(xiàn)Java中Map對象功能的方法,可實現(xiàn)類似Java中Map對象增刪改查等功能,具有一定參考借鑒價值,需要的朋友可以參考下2015-01-01