当前位置: 移动技术网 > IT编程>开发语言>JavaScript > 深入解析JavaScript中的数字对象与字符串对象

深入解析JavaScript中的数字对象与字符串对象

2019年08月01日  | 移动技术网IT编程  | 我要评论

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.
下表列出其他特殊字符,可以使用反斜线转义特殊字符:
http://www.lhsxpumps.com/_images4/10qianwan/20190801/b_0_201908011653078918.jpg

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网