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()的更多相关文章

  1. JavaScript学习笔记-基础语法、类型、变量

    基础语法.类型.变量   非数字值的判断方法:(因为Infinity和NaN他们不等于任何值,包括自身) 1.用x != x ,当x为NaN时才返回true; 2.用isNaN(x) ,当x为NaN或 ...

  2. JavaScript学习笔记(五)——类型、转换、相等、字符串

    第六章 类型 相等 转换等 一.类型 1 typeof(); typeof是一个内置的JavaScript运算符,可用于探测其操作数的类型. 例: <script language=" ...

  3. javascript学习笔记 - 引用类型 基本包装类型

    六 基本包装类型 Boolean,Number,String 这三个引用类型亦称为基本包装类型,与基本的数据类型boolean,number,string相关联.为了方便操作这些基本类型的数据. 引用 ...

  4. javascript学习笔记(四) Number 数字类型

    数字格式化方法toFixed().toExponential().toPrecision(),三个方法都四舍五入 toFixed() 方法指定小数位个数  toExponential() 方法 用科学 ...

  5. JavaScript学习笔记[0]

    JavaScript学习笔记[0] 使用的是廖雪峰JavaScript教程. 数据类型 Number 表示数字,不区分浮点整形. === 比较时不转化数据类型. == 反之. NaN与任何值都不想等, ...

  6. JavaScript:学习笔记(2)——基本概念与数据类型

    JavaScript:学习笔记(2)——基本概念与数据类型 语法 1.区分大小写.Test 和 test 是完全不同的两个变量. 2.语句最好以分号结束,也就是说不以分号结束也可以. 变量 1.JS的 ...

  7. Java程序猿的JavaScript学习笔记(9—— jQuery工具方法)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  8. Java程序猿JavaScript学习笔记(2——复制和继承财产)

    计划和完成在这个例子中,音符的以下序列: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaSc ...

  9. Java程序猿的JavaScript学习笔记(12——jQuery-扩展选择器)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

随机推荐

  1. Linux Shell函数

    200 ? "200px" : this.width)!important;} --> 介绍 正文 $? $?是shell变量,表示"最后一次执行命令"的 ...

  2. 记录排查解决Hubble.Net连接Oracle数据库建立镜像库数据丢失的问题

    起因 前几天在弄Hubble连接Oracle数据库,然后在mongodb中建立一个镜像数据库; 发现一个问题,原本数据是11W,但是镜像库中只有6w多条; 刚开始以为是没运行好,又rebuild了一下 ...

  3. iOS ARC模式 内存管理

     1,测试一 ;i<;i++) { NSLog(@"i = %d",i); } 2,测试二 ;i<;i++) { NSLog(@"i = %d",i ...

  4. Java程序员的日常 —— 多进程开发

    最近再弄进程管理相关的工作,因此必要的就涉及到各种系统下关于进程的管理. 这里简单的介绍下: 如何在Java中执行命令 在windows下肯定是dos命令了,而在linux则为shell命令.执行的方 ...

  5. Atitit 破解qq空间(2)-------探测权限

    Atitit 破解qq空间(2)-------探测权限 /AtiPlatf_cms/src/com/attilax/net/httpTest.java  package com.attilax.net ...

  6. KnockoutJS 3.X API 第三章 计算监控属性(5) 参考手册

    计算监控属性构造参考 计算监控属性可使用以下形式进行构造: ko.computed( evaluator [, targetObject, options] ) - 这种形式是创建一个计算监控属性最常 ...

  7. WPF combobox

    先写一个数据类Grade.cs using System; using System.Collections.Generic; using System.Linq; using System.Text ...

  8. DOM动态脚本和动态样式

    动态脚本 [定义] 在页面加载时不存在,但将来的某一时刻通过修改DOM动态添加的脚本. [方式] [1]插入外部文件方式 var script = document.createElement(&qu ...

  9. 【原创】.NET读写Excel工具Spire.Xls使用(5)重量级的Excel图表功能

                  本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/4288836.html .NET读写Excel工具Spire.Xls使用文章 ...

  10. 理论到实践,A/B测试不得不直面的4个统计学问题

    有放回?无放回? 从总体中随机抽取一个容量为n的样本,当样本容量 n足够大(通常要求n ≥30)时,无论总体是否符合正态分布,样本均值都会趋于正态分布.期望和总体相同,方差为总体的1/n.这即是中心极 ...