深入解析JavaScript中的数字对象与字符串对象
作者:bea
JavaScript Number 对象 JavaScript 只有一种数字类型。 可以使用也可以不使用小数点来书写数字。 JavaScript 数字 JavaScript 数字可以使用也可以不使用小数点来书写: 实例 var pi=3.14; // 使用小数点var x=34; // 不使用小数点 极大或极小的数字可通过科学(指数)计数法来写: 实例 var y=123e5; // 12300000var z=123e-5; // 0.00123
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. 下表列出其他特殊字符,可以使用反斜线转义特殊字符:
有用 | 无用
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. 下表列出其他特殊字符,可以使用反斜线转义特殊字符:
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- jQuery实现右侧显示可向左滑动展示的深色QQ客服效果代码
- js显示当前日期时间和星期几
- js检测用户输入密码强度
- 使用JQuery实现Ctrl+Enter提交表单的方法
- 实例详解angularjs和ajax的结合使用
- jQuery多级手风琴菜单实例讲解
- 使用jquery插件qrcode生成二维码
- JavaScrip调试技巧之断点调试
- 浅析JavaScript 调试方法和技巧
- JS+CSS实现的竖向简洁折叠菜单效果代码
- 浅谈node.js中async异步编程
- JS实现不使用图片仿Windows右键菜单效果代码
- JS实现新浪博客左侧的Blog管理菜单效果代码
- JS+CSS实现大气清新的滑动菜单效果代码
- Webpack 实现 Node.js 代码热替换
- JS+CSS实现仿msn风格选项卡效果代码
- Node.js巧妙实现Web应用代码热更新
- 深入剖析JavaScript编程中的对象概念
- JavaScript中Boolean对象的属性解析