首頁 >web前端 >js教程 >深入解析JavaScript中的數字物件與字串物件_基礎知識

深入解析JavaScript中的數字物件與字串物件_基礎知識

WBOY
WBOY原創
2016-05-16 15:35:441212瀏覽

JavaScript Number 物件
JavaScript 只有一種數字型別。
可以使用也可以不使用小數點來書寫數字。
JavaScript 數字
JavaScript 數字可以使用也可以不用小數點來書寫:
實例

var pi=3.14;  // 使用小数点
var x=34;    // 不使用小数点


極大或極小的數字可用科學(指數)計數法來寫:
實例

var y=123e5;  // 12300000
var z=123e-5;  // 0.00123

所有 JavaScript 數字均為 64 位元
JavaScript 不是型別語言。與許多其他程式語言不同,JavaScript 不定義不同類型的數字,例如整數、短、長、浮點等等。
在JavaScript中,數字不分為整數型別和浮點型別,所有的數字都是由 浮點型別。 JavaScript採用IEEE754標準定義的64位元浮點格式表示數字,它能表示最大值為±1.7976931348623157 x 10308,最小值為±5 x 10 -324
值 (aka Fraction/Mantissa) 指數 Sign

52 bits (0 - 51) 11 bits (50 - 62) 1 bit (63)

精準度
整數(不使用小數點或指數計數法)最多為 15 位。
小數的最大位數是 17,但浮點運算並不總是 100% 準確:
實例

var x = 0.2+0.1; // result will be 0.30000000000000004


八進位和十六進位
如果前綴為 0,則 JavaScript 會把數值常數解釋為八進位數,如果前綴為 0 和 "x",則解釋為十六進位數。
實例

var y = 0377; 
var z = 0xFF;


lamp 絕對不要在數字前面寫零,除非您需要進行八進位轉換。
預設情況下,JavaScript 數字為十進位顯示。
但是你可以使用 toString() 方法 輸出16進位、8進位、2進位。
實例

var myNumber=128;
myNumber.toString(16);  // returns 80
myNumber.toString(8);  // returns 200
myNumber.toString(2);  // returns 10000000


無窮大(Infinity)
當數字運算結果超過了JavaScript所能表示的數字上限(溢位),結果為一個特殊的無限大(infinity)值,在JavaScript中以Infinity表示。同樣地,當負數的值超過了JavaScript所能表示的負數範圍,結果為負無窮大,在JavaScript中以-Infinity表示。無窮大值的行為特性和我們所期望的是一致的:基於它們的加、減、乘和除運算結果還是無限大(當然還保留它們的正負號)。
實例

myNumber=2;
while (myNumber!=Infinity)
{
myNumber=myNumber*myNumber; // Calculate until Infinity
}

除以0也產生了無限:
實例

var x = 2/0;
var y = -2/0;


NaN - 非數字值
NaN 屬性是代表非數字值的特殊值。此屬性用於指示某個值不是數字。可以把 Number 物件設定為該值,來指示其不是數字值。
你可以使用 isNaN() 全域函數來判斷一個值是否是 NaN 值。
實例

var x = 1000 / "Apple";
isNaN(x); // returns true
var y = 100 / "1000";
isNaN(y); // returns false

除以0是無窮大,無窮大是一個數字:
實例

var x = 1000 / 0;
isNaN(x); // returns false


數字可以是數字或物件
數字可以私有資料進行初始化,就像 x = 123;
JavaScript 數位物件初始化數據, var y = new Number(123);
實例

var x = 123;
var y = new Number(123);
typeof(x) // returns Number
typeof(y) // returns Object

實例

var x = 123;       
var y = new Number(123);
(x === y) // is false because x is a number and y is an object.

JavaScript 字串(String) 物件
String 物件用於處理已有的字元區塊。
JavaScript 字串
一個字串用於儲存一系列字元就像 "John Doe".
一個字串可以使用單引號或雙引號:
實例

var carname="Volvo XC60";
var carname='Volvo XC60';


你使用位置(索引)可以存取字串中任何的字元:
實例

var character=carname[7];


字串的索引從零開始, 所以字串第一字元為 [0],第二個字元為 [1], 等等。
你可以在字串中使用引號,如下實例:
實例

var answer="It's alright";
var answer="He is called 'Johnny'";
var answer='He is called "Johnny"';


或者你可以在字串中使用轉義字元使用引號:
實例

var answer='It's alright';
var answer="He is called "Johnny"";

字串(String)
字串(String)使用長度屬性length來計算字串的長度:
實例

var txt="Hello World!";
document.write(txt.length);

var txt="ABCDEFGHIJKLMNOPQRSTUVWXYZ";
document.write(txt.length);

在字串中尋找字串
字串使用 indexOf() 來定位字串中某一個指定的字元首次出現的位置:
實例

var str="Hello world, welcome to the universe.";
var n=str.indexOf("welcome");

如果沒找到對應的字元函數回傳-1
lastIndexOf() 方法在字串結尾開始尋找字串出現的位置。
內容匹配
match()函數用來尋找字串中特定的字符,並且如果找到的話,則傳回這個字符。
實例

var str="Hello world!";
document.write(str.match("world") + "<br>");
document.write(str.match("World") + "<br>");
document.write(str.match("world!"));

替换内容
replace() 方法在字符串中用某些字符替换另一些字符。
实例

str="Please visit Microsoft!"
var n=str.replace("Microsoft","w3cschool");

字符串大小写转换
字符串大小写转换使用函数 toUpperCase() / toLowerCase():
实例

var txt="Hello World!";    // String
var txt1=txt.toUpperCase();  // txt1 is txt converted to upper
var txt2=txt.toLowerCase();  // txt2 is txt converted to lower

字符串转为数组
字符串使用strong>split()函数转为数组:
实例

txt="a,b,c,d,e"  // String
txt.split(",");  // Split on commas
txt.split(" ");  // Split on spaces
txt.split("|");  // Split on pipe 

特殊字符
Javascript 中可以使用反斜线()插入特殊符号,如:撇号,引号等其他特殊符号。
查看如下 JavaScript 代码:

var txt="We are the so-called "Vikings" from the north.";
document.write(txt);


在JavaScript中,字符串的开始和停止使用单引号或双引号。这意味着,上面的字符串将被切成: We are the so-called
解决以上的问题可以使用反斜线来转义引号:

var txt="We are the so-called \"Vikings\" from the north.";
document.write(txt);


JavaScript将输出正确的文本字符串:We are the so-called "Vikings" from the north.
下表列出其他特殊字符,可以使用反斜线转义特殊字符:
深入解析JavaScript中的數字物件與字串物件_基礎知識

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