1.ECMAScript数值的范围

  由于内存的限制,在大多数浏览器中,ECMAScript能够拿保存的数据的范围是 5e-324 ~ 1.7976931348623157e+308,其中最小的数值保存在Number.MIN_VALUE中,最大的数值保存在Number.MAX_VALUE中。

  如果在计算的结果超出这个数值的范围,这个数值会自动被转换成特殊的Infinity值,具体来说,如果是负数,会被转换成 -Infinity(负无穷),如果是正的,会被转换成 +Infinity(正无穷)。

  需要注意的是,如果某次计算返回的是正或者负的Infinity,则该值将无法继续参加下一次的计算,因为Infinity不是能过参与计算的数值。

  使用 isFinite()函数,可以确定一个数是否是有穷,isFinite()函数在参数位于最小和最大数值之间时会返回true。

  eg:

  var age=18;
    alert(isFinite(age));

结果:

2.NaN值:NaN即非数值(Not a Number)是一个特殊的数值,这个数值用来表示一个本来返回数值的操作数未返回数值的情况(这样就不会抛出错误)

  eg:在其他编程语言中,任何数值除以0都有会导致错误从而停止代码的执行。但是在ECMAScript中,任何数字除以0都会返回NaN,因此不会影响其他代码的执行。

(对上文黄色部分进行说明,在高程书上是这么写的,但是在实际上,只有0除以0才会返回NaN值,正数除以0,返回的是Infinity,负数除以0,返回的 -Infinity)详见以下实例:

var age=0;
 alert(age/0);

var age=18;
    alert(age/0);

var age=-18;
    alert(age/0);

  (1)NaN值的两个特性:

  任何涉及NaN的操作都会返回NaN。

  NaN值和任何值都不相等,包括NaN本身。

  (2)isNaN()函数,该函数接收一个参数,如果该参数不是数值,它会尝试将该值转换为数值,而任何不能转换为数值的值会导致这个函数返回 true。

  (3)isNaN()也适用于对象,详见后面的章节。

3.数值转换

  有三个函数可以把非数值转换为数值:

  Number()

  parseInt()

  parseFloat()

  

  Number()可用于任何数据类型,parseInt()和parseFloat()专门用于吧字符串转换为数值。

(1)Number()函数的具体转换规则见高程书P30~31.

(2)由于Number()函数在转换字符串是比较复杂而且不够合理,因此在处理整数的时候更常用的是parseInt()函数。高程P31。

(3)在使用parseInt()函数解析八进制字面量字符串时,ECMAScript 3 和ECMAScript 5 存在不同:

  var num=parseInt(“070”);

  ECMAScript 3 认为是56(八进制),ECMAScript 5 认为是70(十进制)。因为在ECMAScript 5  Javascript引擎中,parseInt()已经有解析不具有解析八进制的能力。在ECMAScript 5 中,即使是在非严格模式下也是如此。

(4)可以为parseInt()函数设置第二个参数,即转化时使用的基数(多少进制)。指定基数会影响到转换的输出结果:

eg:

  1. var num1=parseInt("10",2);
  2. var num2=parseInt("10",8);
  3. var num3=parseInt("10",10);
  4. var num4=parseInt("10",16);
  5. alert(num1);
  6. alert(num2);
  7. alert(num3);
  8. alert(num4);

结果图如下:

注意:

  不指定基数意味着让parseInt()决定如何解析输入的字符串,因此为了避免错误的解析,我们在使用该函数时最好指定基数,多数情况下,我们要解析的都是十进制数值,因此始终将10作为第二个参数是十分有必要的。

(5)parseFloat()函数

  parseFloat()与paserInt()类似,也是从第一个字符(位置0)开始解析每一个字符,也是解析到字符串的尾部或是解析到遇到一个无效的浮点数字符为止。

  也就是说,字符串的第一个小数点是有效的,而第二个小数点是无效的,因此它后面的字符串将被忽略。

注意:

  parseFloat()只解析十进制值,它始终会忽略前导0。

  parseFloat()可以识别所有的浮点数格式。

  eg: var num=parseFloat(“3.125e7”);  //31250000

4.String类型

  String类型用于表示有零个或多个16位Unicode字符组成的字符序列,即字符串。可以有单引号或是双引号表示,但是不能混合使用。

(1)字符字面量

  String数据类型包含一些特殊的字符字面量,叫做转义序列。(详见高程书P33)

(2)length属性

  任何字符串的长度都可以通过该访问其length属性取得。

  eg:

  

  1. var text="hello LIN!"
  2. alert(text.length);

包括text中的空格符,该字符串的长度是10。

注意:这个属性返回的字符数包括16位字符的数目,如果字符串包含双字节字符,那么length属性可能不会精确地返回字符串中的字符数目。

(3)字符串的特点

  ECMAScript中字符串是不可变的,字符串一旦被创建,它们的值就不会改变,要改变某个变量保存的字符串,首先要销毁原来的字符串,然后再另一个新值的字符串填充该变量。

  eg:

  var lang=“java”;

  lang=lang+“Script”;

实现这个操作的过程是:

  首先创建一个能容纳10个字符的新字符串,然后在这个字符串中填充“java”和“Script”,最后一步销毁原来的字符串“java”和“Script”,因为这两个字符串已经没有用了。(这个过程在后台发生,这也是一些旧版本的浏览器在拼接字符串时速度很慢的原因。)

(4)转换为字符串

  toString()方法——返回相应值的字符串表现。

  数值,布尔值,对象和字符串值都有toString()方法。(对的,字符串也都有一个toString()方法,该方法返回字符串的一个副本。)

  一般情况下,调用toString()不用传递参数,但是在调用数值的toString()方法时,可以传递一个参数:输出数值的基数。 

  eg:

  1. var num=10;
  2. alert(num.toString());
  3. alert(num.toString(2));
  4. alert(num.toString(8));
  5. alert(num.toString(10));
  6. alert(num.toString(16));

 结果图依次如下:

  

  String()——该转型函数能够将任何类型的值转换成字符串。String()函数遵循的规则如下:

  如果值有toString()方法,则调用该方法并返回相应的结果。

  如果值是null,这返回“null”。

  如果值是undefined,则返回“undefined”。

5.Object类型

  ECMAScript中的对象其实就是一组数据和功能的集合。对象可以通过执行new操作符后跟要创建的对象类型的名称来创建。而创建Object类型的实例并为其添加属性和(或是)方法,就可以创建自定义对象。

eg: var o=new object();

Object的实例具有的属性和方法详见高程P35。

  

JS高程3.基本概念(3)的更多相关文章

  1. JS高程3.基本概念(4)操作符

    ECMA-262用于操作数据值的操作符包括: 算术操作符 位操作符 关系操作符 相等操作符 ECMAScript操作符的不同之处在于:它能够适用于很多值,包括字符串,数字值,布尔值,甚至是对象.(在应 ...

  2. JS高程3.基本概念(2)

    1.ECMAScript数据类型 5种简单数据类型,分别是: Undefined Null Boolean Number String 1种复杂数据类型: Object (1)typeof操作符--检 ...

  3. JS高程3.基本概念(1)

    1.语法 (1)ECMAScript中的一切(变量,函数名和操作符)都是区分大小写的. (2)标识符 标识符的第一个字符必须是字母,下划线或是美元符号. 其他字符可以是字母,下划线,美元符号和数字. ...

  4. JS高程3.基本概念(6)函数

    1.ECMAScript中的函数使用function关键字来声明. eg: function sum (num1,num2){ alert(num1+num2); } sum(3,7); 注意: 在有 ...

  5. JS高程3.基本概念(5)语句

    1.if语句 2.do-while语句:后测循环语句,循环体内的代码至少执行一次. 3.while语句:前测循环语句. 4.for语句:前测循环语句. 注意:在ECMAScript中不存在块级作用域, ...

  6. js 高程 函数节流 throttle() 分析与优化

    在 js 高程 22.3.3章节 里看到了 函数节流 的概念,觉得给出的代码可以优化,并且概念理解可以清晰些,所以总结如下: 先看 函数节流 的定义,书上原话(斜体表示): 产生原因/适用场景: 浏览 ...

  7. 吃透Javascript数组操作的正确姿势—再读《Js高程》

    Javascript中关于数组对象的操作方法比较多也比较杂,正好再次捡起<Javascript高级程序设计>来读,把它们一一总结梳理了一下: 方法类别 方法名称 方法描述 参数 返回值 备 ...

  8. 《JS高程》创建对象的7种方式(完整版)

    一.理解对象 ECMA-262定义对象:无序属性的集合,其属性可以包含基本值.对象或者属性. 我们可以把 ECMAScript 的对象想象成 散列表:无非就是一组 名值对,其中值可以是数据或函数. 创 ...

  9. 《JS高程》事件学习笔记

    事件:文档或浏览器窗口中发生的一些特定的交互瞬间,也即用户或浏览器自身执行的某种动作. -------------------------------------------------------- ...

随机推荐

  1. iOS-数据持久化详细介绍

    1.iOS-数据解析XML解析的多种平台介绍 2.iOS-数据持久化基础-JSON与XML数据解析 3.iOS-数据持久化基础-沙盒机制 4.   数据持久化的几种方式: 1)plist(XML属性列 ...

  2. 探讨Js的事件的冒泡阶段

    近来看到了一个新的知识点叫Js的事件冒泡,因此决定自己来研究一番. 大家应该都知道,Js中的事件处理分为三个阶段,1:事件的捕获阶段,2:处于目标阶段,3:事件的冒泡阶段.那么什么是事件的捕获和冒泡呢 ...

  3. JavaScript必须了解的知识点总结。

    整理的知识点不全面但是很实用. 主要分三块: (1)JS代码预解析原理(包括三个段落): (2)函数相关(包括 函数传参,带参数函数的调用方式,闭包): (3)面向对象(包括 对象创建.原型链,数据类 ...

  4. WaitType:ASYNC_IO_COMPLETION

    项目组有一个数据库备份的Job运行异常,该Job将备份数据存储到remote server上,平时5个小时就能完成的备份操作,现在运行19个小时还没有完成,backup命令的Wait type是 AS ...

  5. Security3: Schema 和 Permission

    Schema是Object的容器,授予对Schema访问的权限,就是授予对Schema下所有object的访问权限. 一,Schema 是object的container The new schema ...

  6. VS中行号对齐的辅助线(虚线)去除

    3张图 2 3

  7. Android性能优化之UncaughtExceptionHandler定制自己的错误日志系统

    前言: 每当我们app测试的时候,测试人员总是对我们说这里崩溃了,那里挂掉了!我们只能默默接受,然后尝试着重现bug,更可悲的是有时候bug很难复现,为了解决这种现状所以我们要尝试这建立一个自己的bu ...

  8. Linux笔记之——Linux关机命令详解(转)

    原文连接:http://www.jb51.net/os/RedHat/1334.html 在linux下一些常用的关机/重启命令有shutdown.halt.reboot.及init,它们都可以达到重 ...

  9. Android随笔之——模拟按键操作的几种方式

    前几天转过一篇Android上模拟按键操作.触屏事件的博客,昨天又去找了百度.谷歌了一下,写了一点简单的测试代码,留待不时之需.有需要看之前转载的那篇博客的请看这里→_→转:Android随笔之——使 ...

  10. gulp自动化构建工具

    gulp    自动化构建工具,实时监控.代码合并.压缩... http://www.gulpjs.com.cn/     中文网 http://gulpjs.com/plugins/     英文网 ...