数据类型-Number

Number有 整数 、浮点数值Nan之分。

整数基本的数值字面量格式是十进制,还有八进制和十六进制

十进制可以直接输入:

var intNum=55;//整数

八进制第一位必须是0,然后是八进制数字序列(0~7),如果字面值的数值超出了范围,那么前导0将被忽略,后面的数值将被当作十进制数值解析。如下例子:

var octalNum1=070;//八进制的56

var octalNum2=079;//数值9在八进制中是无效的,因此会被解析为79

var octalNum3=08;//无效的八进制,会被解析为8

注意:八进制字面量在严格模式下面是无效的,会抛出错误!

十六进制字面量的前两位必须是0x,后面跟任何的十六进制数字(0~9及A~F),字母可以大写或小写。如下例子:

var hexNum1=0xA;//十六进制的10

var hexNum2=0x1f;//十六进制的31

在进行计算时,所有的八进制和十六进制表示的数值最终都被转换成十进制数值。

浮点数值就是该数值中必须包含一个小数点,并且小数点后面必须只有一位数字。小数点前可没有数字,但不推荐。例如:

var floatNum1=1.1;

var floatNum2=0.1;

var floatNum3=.1;//不推荐

浮点数值对于极大或极小的数值,可以用e来表示(即科学计数法)。用e表示法表示的数值等于e前面的数值乘以10的指数次幂。例如:

var floatNum1=3.125e7;//等于31250000

var floatNum2=3.125e-7;//等于-31250000

浮点数值的最高精度是17位小数,但在计算的时候会有在特殊组合的计算方式上会有误差,例如:

0.1+0.2=0.30000000000000004;//并不是0.3

由于内存限制,ECMAScript并不能保存世界上所有的数值。ECMAScript能够表示的最小数值保存在Number.MIN_VALUE中,这个值是5e-324;能够表示最大数值保存在Number.MAX_VALUE中,这个值是1.7976931348623157e+308。如果某次计算的结果得到了一个超出Javascript数值范围的值,那么这个数值将被自动转换成特殊的Infinity值。如果这个数值是负数,则会被转成-Infinity(负无穷),如果这个数值是正数,则会被转成Infinity(正无穷)。
函数isFinite()可检测是否超过范围,例:

var result=Number.MAX_VALUE+Number.MIN_VALUE;

alert(isFinite(result));//true

NaN,非数值(Not a Number)是一个特殊的数值,这个数值用于表示一个本来要返回数值的操作数未返回数值的情况(这样就不会抛出错误了)。例如在其他的编程语言中,任何数值除以0都会导致错误,从而停止代码执行。但是在ECMAScript中,任何数值除以0会返回NaN,因此不会影响其他的代码执行。
NaN本身有两个非同寻常的特点。

首先,任何涉及NaN的操作(例:NaN/10)都会返回NaN,这个特点在多步计算中可能导致问题。

其次,NaN与任何值都不相等,包括NaN本身。例如:

alert(NaN==NaN);//fales

针对这两个特点,ECMAScript定义了isNaN()函数。这个函数接受一个参数,该参数可以是任何类型,而函数会帮我们确定这个参数是否“不是数值”。isNaN()在接收到一个值之后,会尝试将这个数值转换为数值。某些不是数值的值会直接转换为数值,例如字符窜“10”或Boolean值。而任何不能被转换为数值的值都会导致这个函数返回true。例如:

alert(isNaN(NaN));//true

alert(isNaN(10));//false(10是一个数值)

alert(isNaN("10"));//false(可以被转换成数值10)

alert(isNaN("blue));//true

alert(isNaN(true));//false(true可以转换成数值1)

有三个函数可以把非数值转换为数值:Number(),pareseInt()和pareseFloat()。

Number()可以用于任何数据类型。

而parseInt()和parseFloat()则专门用于把字符窜转换成数值。

  Number()函数的转换规则如下:

    •如果是Boolean值,true和false将分别被转换为1和0。

    •如果是数字值,只是简单的穿任何返回。

    •如果是null值,返回0。

    •如果是undefined,返回NaN。

    •如果是字符串,则遵循下列规则:

      1.如果字符串中只包含数字(包括前面带正号或负号的情况),则将其转换为十进制数值,即“1”会变成1,“123”会变成123,而“011”会变成                        11;

      2.如果字符串中包含有效的浮点格式,如“1.1”,则将其转换为对应的浮点数值(同样,也会忽略前导);

      3.如果字符串中包含有效的十六进制格式,例如“0xf”,则将其转换为相同大小的十进制整数数值;

      4.如果字符串是空的(不包含任何数字),则将其转换为0;

    •如果是对象,则调用对象的toString()方法,然后依照前面的规则转换返回额值。如果转换的结果是NaN,则对象的toString()方法,然后再次依照恰          面的规则转换返回的字符串值。

      5.如果字符窜中包含除上述格式之外的字符,则将其转换为NaN。

  根据规则看如下例子: 

    var num1=Number("hello word");//NaN

    var num2=Number("");//0

    var num3=Number("0000011");//11

    var num4=Number("ture");//1

  parseInt()它会忽略字符串前面的空格,直到找到第一个个非空格字符。如果第一个字符不是数字字符或者负号,就会返回NaN。

  parseInt()也能够识别出各种整数格式(十进制,八进制和十六进制)。就因为这样可以识,我们应该给指定第二个参数指明是多少进制。例如:

    var num1=parseInt("AF",16);//按十六进制解析,175

    var num2=parseInt("10",2);//按二进制解析,2

    var num3=parseInt("10",8);//按八进制解析,8

    var num4=parseInt("10",10);//按十进制解析,10

    var num5=parseInt("10",16);//按十六进制解析,16

parseFloat()与parseInt()函数类似,也是从第一个字符(位置0)开始解析每个字符。而且也是一直解析到字符串末尾,或者解析到遇见一个无效的浮点数字字符为止。也就是说 ,字符串中的第一小数点是有效的,而第二个小数点就是无效的了,因此它后面的字符串将被忽略。例如:

  alert(parseFloat("22.23.23"));//22.23

与parseInt()不同的是它只解析十进制的值,因此它没有用第二个参数指定基础数的用法。
注意:如果字符串包含的是一个可解析为整数的数(没有小数点,或者小数点都是0),它会返回整数。

下面是使用parseFloat()转换数值的几个典型示例:

var num1=parseFloat("1234blue");//1234

var num2=parseFloat("0xA");//0

var num3=parseFloat("22.5");//22.5

var num4=parseFloat("22.34.5");//22.34

var num5=parseFloat("0908.5");//908.5

var num6=parseFloat("3.125e7");//31250000
时间: 2024-11-13 03:45:39

数据类型-Number的相关文章

Javascript数据类型——number类型

        ECMAScript规范中使用IEEE754格式来表示整数和浮点数.支持十进制.八进制以及十六进制.有一点注意的是八进制数字在严格模式下是无效的,这可能会影响到程序的正常运行. 避免浮点数等值判断:       众所周知,基于IEEE754进行数据计算会产生舍入误差,最为经典的例子: 0.1+0.2 = 0.30000000000000004 ; 0.15+0.15 = 0.3;        在实际开发中应尽量避免使用浮点数的等值判断. NaN:      关于NaN有两点特别

oracle数据类型number 为null 判断

number 可以是整数,也可以是含小数点的小数 操作项: a(number(18,2)),b(number(18,2)), +相加) 1.如果操作项有一个为 null, 相加结果为null ,a+null= null 2.正确写法:nvl(a,0)+nvl(b,0) sum 求和并相加)(sum求和 会自动把null值补0) 1.此写法结果错误: result1=sum(a+b) 2.此写法结果错误: result2= sum(a)+sum(b) .出错原因为:sum(null+null) =

oracle表数据类型number对应java中BIgDecimal转int

oracle中id为number类型,在java获取id时用getBigDecimal 相匹配, 如果想转换成int,重写model中的getInt方法: 1 public Integer getInt(String attr) { 2 return getNumber(attr).intValue(); 3 } 如此,即可调用model.getInt(id),而不是每次转换BIgDecimal了. 但是,在jfinal中Db模式应该还是不可以.

javascript中的数据类型number

1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="UTF-8"> 5 <title></title> 6 <script type="text/javascript"> 7 8 /* 9 * 在JS中所有的数值都是Number类型, 10 * 包括整数和浮点数(小数) 11 * 12 * JS中可以表示的数字的最大值 13 *

JS中的Number数据类型详解

Number数据类型 Number类型使用IEEE754格式来表示整数和浮点值,这也是0.2 + 0.3不等于0.5的原因, 最基本的数值类型字面量格式是十进制整数 var a = 10; 1. 浮点数值 2. NaN Not a Number:不是一个数,但它属于数值类型 NaN的特点 NaN和任何值进行操作都会返回NaN NaN与任何值都不相等,包括NaN本身 console.log(NaN == NaN) 3. isNaM函数 用于检测一个变量不是数值(Number)类型.isNaN()接

javasript数据类型以及如何判断数据类型

在javascript里面一共有5种基本的数据类型,分别是:Number,String,Boolean,Null,Undefined7种引用类型,分别是:Object类型,Array类型,Date类型,RegExp类型,Function类型,基本包装类型,单体内置对象.*注"引用类型的值(对象)是引用类型的一个实例.在ECMAScript中,用于将数据和功能结合在一起.它长被成为类,但这种称呼并不恰当"[1]其中如何判断数据类型,当我们要判断一个变量属于什么数据类型时,javascri

数据类型及数据类型的检测

基本数据类型 number  string  boolean  underfined  null: 引用数据类型 Object  Array  RegExp: typeof 检测数据类型 但是不能检测(对象.数组.正则) instanceof/constructor检测某一个实例是否属于一个类: 我们的constructor可以避免instanceof检测的时候,用Object也是true的问题: console.log([].constructor === Object);//->false

javascript数据类型(一)

一.定义 1.数据类型决定了一个数据的特征,限定了该数据类型必须按照一定的规则进行操作. 2.特定的数据类型会有其想对应的行为模式. 3.javascript中有6中数据类型 Number --数值型 boolean --布尔型 string --字符串型 Null --空 undefined --未定义 Object --对象型 4.值和对象的区别,数据类型的实例被称为"值",Obj类型的实例被称为"对象",不过javascript支持值与对象的隐式变换. 二.基

oracle中的number类型

number 数据类型 number (precision,scale) a)    precision表示数字中的有效位,如果没有指定precision的话,oracle将使用38作为精度: b)    如果scale大于零,表示数字精度到小数点右边的位数:scale默认设置为0:如果scale小于零,oracle将把该数字取舍到小数点左边的指定位数. c)    Precision 的取值范围是[1-38];scale的取值范围是[-84-127]. d)    Number整数部分允许的长