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


Posted in Javascript onOctober 21, 2015

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中的数字对象与字符串对象

Javascript 相关文章推荐
EASYUI TREEGRID异步加载数据实现方法
Aug 22 Javascript
JS+CSS制作DIV层可(最小化/拖拽/排序)功能实现代码
Feb 25 Javascript
改变状态栏文字的js代码
Jun 13 Javascript
解决Jquery向页面append新元素之后事件的绑定问题
Mar 16 Javascript
javascript为按钮注册回车事件(设置默认按钮)的方法
May 09 Javascript
JS事件添加和移出的兼容写法示例
Jun 20 Javascript
jQuery插件版本冲突的处理方法分析
Jan 16 Javascript
利用Node.js编写跨平台的spawn语句详解
Feb 12 Javascript
vue与vue-i18n结合实现后台数据的多语言切换方法
Mar 08 Javascript
JavaScript循环遍历你会用哪些之小结篇
Sep 28 Javascript
javascript canvas API内容整理
Feb 16 Javascript
工作中常用js功能汇总
Nov 07 Javascript
jQuery无刷新切换主题皮肤实例讲解
Oct 21 #Javascript
JavaScript操作HTML元素和样式的方法详解
Oct 21 #Javascript
13个PHP函数超实用
Oct 21 #Javascript
JavaScript对HTML DOM使用EventListener进行操作
Oct 21 #Javascript
JavaScript对象数组的排序处理方法
Oct 21 #Javascript
Javascript刷新窗口方法小结
Oct 21 #Javascript
JavaScript简单遍历DOM对象所有属性的实现方法
Oct 21 #Javascript
You might like
php垃圾代码优化操作代码
2010/08/05 PHP
Smarty局部缓存的几种方法简介
2014/06/17 PHP
smarty的section嵌套循环用法示例
2016/05/28 PHP
功能强大的PHP发邮件类
2016/08/29 PHP
PHP基于redis计数器类定义与用法示例
2018/02/08 PHP
jQuery Ajax文件上传(php)
2009/06/16 Javascript
aspx中利用js实现确认删除代码
2010/07/22 Javascript
非阻塞动态加载javascript广告实现代码
2010/11/17 Javascript
JS实现从表格中动态删除指定行的方法
2015/03/31 Javascript
js闭包实现按秒计数
2015/04/23 Javascript
js实现的早期滑动门菜单效果代码
2015/08/27 Javascript
JS实现新浪博客左侧的Blog管理菜单效果代码
2015/10/22 Javascript
JS中生成随机数的用法及相关函数
2016/01/09 Javascript
jquery分页插件jquery.pagination.js实现无刷新分页
2016/04/01 Javascript
Bootstrap学习笔记之css组件(3)
2016/06/07 Javascript
Json解析的方法小结
2016/06/22 Javascript
bootstrap datetimepicker日期插件使用方法
2017/01/13 Javascript
Angular2开发——组件规划篇
2017/03/28 Javascript
基于canvas粒子系统的构建详解
2017/08/31 Javascript
JS排序算法之冒泡排序,选择排序与插入排序实例分析
2017/12/13 Javascript
Vue插件打包与发布的方法示例
2018/08/20 Javascript
vue 右键菜单插件 简单、可扩展、样式自定义的右键菜单
2018/11/29 Javascript
vue通过数据过滤实现表格合并
2020/11/30 Javascript
javascript canvas API内容整理
2020/02/16 Javascript
详解JavaScript类型判断的四种方法
2020/10/21 Javascript
[49:20]2014 DOTA2国际邀请赛中国区预选赛5.21 CIS VS TongFu
2014/05/22 DOTA
用Python实现一个简单的线程池
2015/04/07 Python
使用Python读写及压缩和解压缩文件的示例
2016/07/08 Python
Python使用Selenium爬取淘宝异步加载的数据方法
2018/12/17 Python
利用python提取wav文件的mfcc方法
2019/01/09 Python
30秒学会30个超实用Python代码片段【收藏版】
2019/10/15 Python
python实现简单银行管理系统
2019/10/25 Python
TensorFlow梯度求解tf.gradients实例
2020/02/04 Python
电子商务专业个人的自我评价分享
2013/10/29 职场文书
试用期自我鉴定范文
2014/03/20 职场文书
英语系毕业生求职信
2014/07/13 职场文书