javascript学习笔记2-typeof、Number类型、Boolean()
1.typeof操作符
对一个值使用typeof操作符可能返回下列某个字符串
- "undefined"——这个值未定义
- "boolean"——这个值是布尔值
- "string"——这个值是字符串
- "number"——这个值是数值
- "object"——这个值是对象或null
- "function"——这个值是函数
var message="some string";
alert(typeof message); //"string"
alert(typeof(message)); //"string"
alert(typeof 95); //"number"
2.Number类型
浮点数值的最高精度是17位小数,进行算术计算时其精确度远远不如整数。例如0.1+0.2结果不是0.3,而是0.3000000000000004.
ECMAScript能够表示的最小值保存在Number.MIN_VALUE中,最大值保存在Number.MAX_VALUE中。
如果某次计算的结果得到了一个超出JavaScript数值范围的值,那么这个值就会被自动转换为特殊的Infinity值。
具体来说,如果这个值是负数,则会被转换为负无穷(-Infinity),如果这个值为正数,则会被转换为Infinity(正无穷) 判断一个数是不是有穷的(位于最小值和最大值之间),使用isFinite()函数。
例如:
var result = Number.MAX_VALUE + Number.MIN_VALUE;
alert(isFinite(result));//false //NaN,非数值(Not a Number)
alert(NaN == NaN);//false
isNaN();//接收一个参数,参数可以是任何类型.
isNaN在接收到一个值之后,会尝试将这个值转换为数值.某些不是数值的值会直接转换为数值,例如字符串"10"或Boolean值.
而任何不能被转换为数值的值都会导致函数返回true
例如:
alert(isNaN(NaN));//true
alert(isNaN(10));//false
alert(isNaN("10"));//false(可以被转换为数值10)
alert(isNaN("blue"));//true
alert(isNaN(true));//false(可以被转换为数值1)
数值转换
Number()、parseInt()和parseFloat()都可以把非数值转换为数值
Number()可以用于任何数据类型,parseInt(),parseFloat()专门用于把字符串转换为数值.
Number()的转换规则如下:
- 如果是Boolean值,true和false分别被转换为1和0
- 如果是数字值,简单的传入和返回
- 如果是null值,返回0
- 如果是undefined,返回NaN
- 如果是字符串,遵循下列规则:
- 如果字符串中只包含数字(包括前面带正号或负号的情况),则将其转换为十进制数值,即"1"会变成1,"123"会变成123,而"011"会变成11(前导的零被忽略了);
- 如果字符串中包含有效的浮点格式,如"1.1",则将其转换为对应的浮点数值(同样会忽略前导零)
- 如果字符串包含有效的十六进制格式,例如"0xf",则将其转换为相同大小的十进制整数值
- 如果字符串是空的(不包含任何字符),则将其转换为0
- 如果字符串中包含除上述字符格式之外的字符,则将其转换为NaN
- 如果是对象,则调用对象的valueOf()方法,然后依照前面的规则转换返回的值.如果转换的结果是NaN,则调用对象的toString()方法,然后再次依照前面的规则转换返回的字符串
例:
var num1 = Number("Hello world!");//NaN
var num2 = Number("");//0
var num3 = Number("000011");//11
var num4 = Number(true);//1
在处理整数的时候果然那个常用的是parseInt()函数.parseInt()转换字符串时,会忽略字符串前面的空格,直到找到第一个非空格字符.
如果第一个字符不是数字字符或者负号,parseInt()会返回NaN;用parseInt()转换空字符串会返回NaN(Number()对空字符返回0).
如果第一个字符是数字字符,parseInt()会继续解析第二个字符,直到解析完所有后续字符或者遇到了一个非数字字符.
例如,"1234blue"会被转换为1234,因为"blue"会被完全忽略.类似的,"22.5"会被转换为22,因为小数点并不是有效的数字字符.
如果字符串中的第一个字符是数字字符,parseInt()也能识别出各种整数格式(即前面讨论的十进制、八进制、十六进制数).也就是说,如果字符串以"0x"开头且后跟数字字符,就会将其当做一个十六进制整数;如果字符串以"0"开头且后跟数字字符,则会将其当做一个八进制数来解析.
例如:
var num1 = parseInt("1234blue"); //1234
var num2 = parseInt(""); //NaN
var num3 = parseInt("0xA"); //10(十六进制数)
var num4 = parseInt(22.5); //22
var num5 = parseInt("070"); //56(八进制数)
var num6 = parseInt("70"); //70(十进制数)
var num7 = parseInt("0xf"); //15(十六进制数)
注意:在使用parseInt()解析像八进制字面量的字符串时,ECMAScript 3和5存在分歧.
例如
//ECMAScript 3认为是56(八进制),ECMAScript 5被认为是0(十进制)
var num = parseInt("070");
在ECMAScript 3 JavaScript引擎中,"070"被当成八进制字面量,因此转换后的值是十进制的56.而在ECMAScript 5 JavaScript引擎中,parseInt()已经不具有解析八进制值的能力,因此前导的零会被认为无效,从而将这个值当成"0",结果就得到十进制的0.在ECMAScript 5中,即使是在严格模式下也会如此.
为了消除在使用parseInt()函数时可能导致的上述困惑,可以为这个函数提供第二个参数:转换时使用的基数(即多少进制).如果知道要解析的值是十六进制格式的字符串,那么指定基数16作为第二个参数,可以保证得到正确的结果,例如:
var num = parseInt("0xAF", 16);//175
实际上,如果指定了16作为第二个参数,字符串可以不带前面的"0x",如下所示:
var num1 = parseInt("AF", 16);//175
var num2 = parseInt("AF");//NaN
这个例子中的第一个转换成功了,第二个失败了.差别在于第一个转换传入了基数,明确告诉parseInt()要解析一个十六进制格式的字符串;而第二个转换发现第一个字符不是数字字符,因此就自动终止了.
指定基数会影响转换的输出结果.例如:
var num1 = parseInt("10", 2);//2(按二进制解析)
var num2 = parseInt("10", 8);//8(按八进制解析)
var num2 = parseInt("10", 10);//10(按十进制解析)
var num2 = parseInt("10", 16);//16(按十六进制解析)
不指定基数意味着让parseInt()决定如何解析输入的字符串,因此为了避免错误的解析,应当指定基数
与parseInt()类似,parseFloat()也是从第一个字符(位置0)开始解析每个字符.而且也是一直解析到字符串的末尾,或者解析到遇见一个无效的浮点数字字符为止.也就是说,字符串中的第一个小数点是有效的,而第二个小数点就是无效的了,因此他后面的字符串将被忽略.举例来说,"22.34.5"将会被解析为22.34.
除第一个小数点有效之外,parseFloat()和parseInt()第二个区别在于他始终都会忽略前导的零.parseFloat()可以识别前面讨论的所有浮点数值格式,也包括十进制整数格式.但十六进制格式的字符串始终会被转换为0.由于parseFloat()只解析十进制值,因此他没有用第二个基数指定基数的用法.最后还要注意一点:如果字符串包含的是一个可解析为整数的数(没有小数点,或者小数点后面都是零),parseFloat()会返回整数.
例如:
var num1 = parseFloat("1234blue"); //1234(整数)
var num2 = parseFloat("0xA"); //0
var num2 = parseFloat("22.5"); //22.5
var num2 = parseFloat("22.34.5"); //22.34
var num2 = parseFloat("0908.5"); //908.5
var num2 = parseFloat("3.125e7"); //31250000
String类型
在不知道要转换的值是不是null或undefined的情况下,还可以使用转型函数String(),这个函数能够将任何类型的值转换为字符串.String()函数遵循下列转换规则:
- 如果值有toString()方法,则调用该方法(没有参数)并返回相应结果;
- 如果值是null,则返回"null";
- 如果值是undefined,则返回"undefined"
var value1 = 10;
var value2 = true;
var value3 = null;
var value4; alert(String(value1)); //"10"
alert(String(value2)); //"true"
alert(String(value3)); //"null"
alert(String(value4)); //"undefined"
这里先后转换了4个值:数值、布尔值、null和undefined.数值和布尔值的转换结果与调用toString()方法得到的结果相同.因为null和undefined没有toString()方法,所以String()函数就返回了这两个值的字面量.
3.Boolean()函数
/*可以对任何数据类型的值调用Boolean()函数,并且总会返回一个Boolean值。
返回的值是true还是false,取决于要转换值的数据类型及其实际值。下表给出了各种数据类型及其对应转换规则*/
| 数据类型 | 转换为true的值 | 转换为false的值 |
| Boolean | true | false |
| String | 任何非空字符串 | 空字符串 |
| Number |
任何非零数字值 (包括无穷大) |
0和NaN |
| Object | 任何对象 | null |
| Undefined |
n/a(not applicable) 不适用 |
undefined |
javascript学习笔记2-typeof、Number类型、Boolean()的更多相关文章
- JavaScript学习笔记-基础语法、类型、变量
基础语法.类型.变量 非数字值的判断方法:(因为Infinity和NaN他们不等于任何值,包括自身) 1.用x != x ,当x为NaN时才返回true; 2.用isNaN(x) ,当x为NaN或 ...
- JavaScript学习笔记(五)——类型、转换、相等、字符串
第六章 类型 相等 转换等 一.类型 1 typeof(); typeof是一个内置的JavaScript运算符,可用于探测其操作数的类型. 例: <script language=" ...
- javascript学习笔记 - 引用类型 基本包装类型
六 基本包装类型 Boolean,Number,String 这三个引用类型亦称为基本包装类型,与基本的数据类型boolean,number,string相关联.为了方便操作这些基本类型的数据. 引用 ...
- javascript学习笔记(四) Number 数字类型
数字格式化方法toFixed().toExponential().toPrecision(),三个方法都四舍五入 toFixed() 方法指定小数位个数 toExponential() 方法 用科学 ...
- JavaScript学习笔记[0]
JavaScript学习笔记[0] 使用的是廖雪峰JavaScript教程. 数据类型 Number 表示数字,不区分浮点整形. === 比较时不转化数据类型. == 反之. NaN与任何值都不想等, ...
- JavaScript:学习笔记(2)——基本概念与数据类型
JavaScript:学习笔记(2)——基本概念与数据类型 语法 1.区分大小写.Test 和 test 是完全不同的两个变量. 2.语句最好以分号结束,也就是说不以分号结束也可以. 变量 1.JS的 ...
- Java程序猿的JavaScript学习笔记(9—— jQuery工具方法)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿JavaScript学习笔记(2——复制和继承财产)
计划和完成在这个例子中,音符的以下序列: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaSc ...
- Java程序猿的JavaScript学习笔记(12——jQuery-扩展选择器)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
随机推荐
- [SQLServer大对象]——FileTable初体验
阅读导航 启用FILESTREAM设置 更改FILESTRAM设置 启用数据库非事务性访问级别 FileTable 在我接触FileTable之前,存储文件都是存储文件的链接和扩展名到数据,其实并没有 ...
- 分享一些Hadoop环境搭建所用到的软件
本来想用土的掉渣的语言说说hadoop配置的,因为最近总有人问我,环境搭建老出莫名其妙的问题,可是写到一半,还是决定不写了,网上教程好多好多,而大家遇到问题有很多是软件版本不对应造成的,因此我就把大家 ...
- ./在Linux下是什么意思
在网上找的答案: . 在这里表示的是当前目录,就像 .. 表示上级目录一样. 这个 / 表示的是目录级别的分隔符,他之前的就是目录名,./aaa/ 表明的就是 . (也就是当前目录)下面的 aaa 目 ...
- 知方可补不足~SQL2005使用ROW_NUMBER() OVER()进行数据分页
回到目录 数据分页是这个经常说的东西,无论在WEBForm还是WinForm中它都会被单独拿出来,或者是公用组件,或者是公用类库,反正对于数据分页这个东西,总是我们关注的一个话题,但事实上,数据分页归 ...
- lua随机数的问题
在看 lua 的 math.random 函数的时候发现一个问题,就是在没有重新设置随机种子的时候, random 返回的前几个随机数并不是那么特别随机,尤其当随机范围很小的时候,比如 100 左右的 ...
- 每天一个linux命令(8):cp 命令
cp命令用来复制文件或者目录,是Linux系统中最常用的命令之一.一般情况下,shell会设置一个别名,在命令行下复制文件时,如果目标文件已经存在,就会询问是否覆盖,不管你是否使用-i参数.但是如果是 ...
- mysql如果数据不存在,则插入新数据,否则更新的实现方法
mysql如果数据不存在,则插入新数据,否则更新的实现方法 //如果不存在,则插入新数据 $sql = "INSERT INTO {$ecs->table('cat_lang')} ( ...
- Web应用安全之文件上传漏洞详解
什么是文件上传漏洞 文件上传漏洞是在用户上传了一个可执行的脚本文件,本通过此脚本文件获得了执行服务器端命令的功能,这种攻击方式是最为直接,最为有效的,有时候,几乎没有什么门槛,也就是任何人都可以进行这 ...
- WPF/Silverlight 下的图片局部放大
最近的项目中也要用到一个局部图片放大的功能,园子里面一搜,发现(菩提下的杨过)杨大侠已经实现了. 请参见这里:http://www.cnblogs.com/yjmyzz/archive/2009/12 ...
- SQL 语句中union all和order by同时使用
最近做的一个财物管理系统中查询过期或逾期的存储过程,返回 “财物所属的案件名称”,“财物名称”,“财物编号”,“过期或逾期时间”(超期或逾期前7天开始预警). 遇到“union all ...