【www.hj8828.com】Javascript学习笔记一 之 数据类型_基础知识_脚本之家

一.数据类型
Javascript是一种弱类型的脚本语言,它一共有6种数据类型,又被分为基础数据类型,特殊数据类型,复合数据类型。
1.基础数据类型:数值型,字符串型,布尔型
2.特殊数据类型:null,undefined(区别在于null需要显性赋值,而undefined表示没有赋值)
3.复合数据类型:Object
注:理解基础数据类型和引用数据类型的区别。如函数参数传递 二.
包装类和基础数据类型的关系

对于基础数据类型,都有相应的包装类与之对应。 Number,String,Boolean
注:基础数据类型会在一定条件下转化成基础类型包装对象 复制代码 代码如下: var
str=”这是一个基础字符串”; var
length=str.length时,Javascript解释引擎会产生
//一个str的临时String对象,执行完后临时对象清除 三.如何判断数据类型
仅可检测出以下6种数据类型:number, string, boolean, undefined, object,
function 复制代码 代码如下: alert;
//结果为object alert; //a未赋值,结果为undefined
因此判断基础数据类型可以如下: 复制代码
代码如下: function type { return ? ‘null’ : typeofinstanceof
但对于复合数据类型,则全部返回object,无法通过typeof判断
可使用instanceof检测某个对象是不是另一个对象的实例,注意instanceof的右操作数必须为对象:
复制代码 代码如下: function Animal {};
Pig.prototype = new Animal instanceof Animal); // true
instanceof不适合用来检测一个对象本身的类型 constructor 复制代码 代码如下: alert; // 报错 var o = 1;
alert; // Number o = null; // or undefined alert; // 报错 alert; //
Object alert; // Boolean 复制代码
代码如下: function isArray { return Object.prototype.toString.call ===
‘[object Array]’; } call和apply的区别:
它们都是Function.prototype的方法,它是Javascript引擎内在实现的。
实际上这两个的作用几乎是相同的,要注意的地方是call(thisObj[,arg1[,
arg2[,)中的arg参数可以是变量,而apply中的参数为数组集合
方法是借给另一个对象的调用去完成任务,原理上是方法执行时上下文对象改变了.
总结 复制代码 代码如下: var _toS =
Object.prototype.toString, _types = { ‘undefined’ : ‘undefined’,
‘number’ : ‘number’, ‘boolean’ : ‘boolean’, ‘string’ : ‘string’,
‘[object Function]’ : ‘function’, ‘[object RegExp]’ : ‘regexp’,
‘[object Array]’ : ‘array’, ‘[object Date]’ : ‘date’, ‘[object
Error]’ : ‘error’ }; function type { return _types[typeof o] ||
_types[_toS.call] || (o ? ‘object’ : ‘null’); } 四.数据类型转换
Javascript有两种数据类型的转换方法:
一种是将整个值从一种类型转换为另一种数据类型,
另一种方法是从一个值中提取另一种类型的值,并完成转换工作。
基本数据类型转换的如以下三种方法: 1.转换为字符型:String的结果为”678″
2.转换为数值型:Number的结果为678 3.转换为布尔型:Boolean的结果为true
从一个值中提取另一种类型的值的如以下方法:
1.提取字符串中的整数:parseInt(); 例:parseInt的结果为123
2.提取字符串中的浮点数:parseFloat(); 例:parseFloat的结果为0.55
另外总结各种类型转换的方法 Number转化成字符串:String 、
Number.toString;//分别代表二进制\八进制\十六进制默认 //保留小数点后3位
toExponextial; //小数点前1位, 小数点后3位如var n=123456.789;
n.toExponextial;//1.234e+5即1.234X105 toPrecision; //返回指定位数
如果位数不够完全显示,则按指数表示法 五.其他总结 1.parseInt的陷阱
以下部分摘自《Javascript精粹》:
parseInt是一个将字符串转换为整数的函数。它遇到非数字时停止解析,所以parseInt与parseInt产生相同的结果。如果该函数提示我们出现了额外文本就好了,但是它不会那么做。
如果该字符串第一个字符时0,那么该字符串将被基于八进制而不是十进制来求值。在八进制中,8和9不是一个数字,所以parseInt产生0作为结果。这个错误导致程序解析日期和时间时出现问题。幸运的是,parseInt可以接受一个基数作为参数,如此一来parseInt结果为8.我建议你总是提供这个基数参数。
另外。下面这个会显示1: alert;
这是由于超过一定精度js就会用科学计数法记录数字,例如: alert;
会得到1e-7,而parseInt会自动把参数转换成字符串的,那实际上就是: 复制代码 代码如下: s = ; alert;
最后得到1就不奇怪了。
使用parseInt必须记住里面参数是转换成字符串再做转换的。

数据类型
  JavaScript中有5种简单数据类型(也称为基本数据类型):Undefined、Null、Boolean、Number和String。还有1种复杂数据类型——Object,Object本质上是由一组无序的名值对组成的。

 typeof操作符

  介于JavaScript是松散类型的,因此需要有一种手段来检测给定变量的数据类型——typeof就是负责提供者方面信息的操作符。对一个值使用typeof操作符可能返回下列某个字符串:

  ● “undefined”——如果这个值未定义;

  ● “boolean”——如果这个值是布尔值;

  ● “string”——如果这个值是字符串;

  ● “number”——如果这个值是数值;

  ● “object”——如果这个值是对象或null;

  ● “function”——如果这个值是函数;

  Undefined类型
  Undefined类型只有一个值,即特殊的undefined。在使用var声明变量但未对其加以初始化时,这个变量的值就是undefined,例如:

复制代码 代码如下:

var message;
alert(message == undefined) //true

  Null类型
  Null类型是第二个只有一个值的数据类型,这个特殊的值是null。从逻辑角度来看,null值表示一个空对象指针,而这也正是使用typeof操作符检测null时会返回”object”的原因,例如:

复制代码 代码如下:

var car = null;
alert(typeof car); // “object”

  如果定义的变量准备在将来用于保存对象,那么最好将该变量初始化为null而不是其他值。这样一来,只要直接检测null值就可以知道相应的变量是否已经保存了一个对象的引用了,例如:

复制代码 代码如下:

if(car != null)
{
//对car对象执行某些操作
}

  实际上,undefined值是派生自null值的,因此ECMA-262规定对它们的相等性测试要返回true。

复制代码 代码如下:

  alert(undefined == null); //true

  尽管null和undefined有这样的关系,但它们的用途完全不同。无论在什么情况下都没有必要把一个变量的值显式地设置为undefined,可是同样的规则对null却不适用。换句话说,只要意在保存对象的变量还没有真正保存对象,就应该明确地让该变量保存null值。这样做不仅可以体现null作为空对象指针的惯例,而且也有助于进一步区分null和undefined。

  Boolean类型

  该类型只有两个字面值:true和false。这两个值与数字值不是一回事,因此true不一定等于1,而false也不一定等于0。

  虽然Boolean类型的字面值只有两个,但JavaScript中所有类型的值都有与这两个Boolean值等价的值。要将一个值转换为其对应的Boolean值,可以调用类型转换函数Boolean(),例如:

复制代码 代码如下:

var message = ‘Hello World’;
var messageAsBoolean = Boolean(message);

  在这个例子中,字符串message被转换成了一个Boolean值,该值被保存在messageAsBoolean变量中。可以对任何数据类型的值调用Boolean()函数,而且总会返回一个Boolean值。至于返回的这个值是true还是false,取决于要转换值的数据类型及其实际值。下表给出了各种数据类型及其对象的转换规则。

www.hj8828.com 1
这些转换规则对理解流控制语句(如if语句)自动执行相应的Boolean转换非常重要,例如:

复制代码 代码如下:

var message = ‘Hello World’;
if(message)
{
alert(“Value is true”);
}

  运行这个示例,就会显示一个警告框,因为字符串message被自动转换成了对应的Boolean值(true)。由于存在这种自动执行的Boolean转换,因此确切地知道在流控制语句中使用的是什么变量至关重要。
  Number类型 这种类型用来表示整数和浮点数值,还有一种特殊的数值,即NaN(非数值 Not
a
Number)。这个数值用于表示一个本来要返回数值的操作数未返回数值的情况(这样就不会抛出错误了)。例如,在其他编程语言中,任何数值除以0都会导致错误,从而停止代码执行。但在JavaScript中,任何数值除以0会返回NaN,因此不会影响其他代码的执行。
  NaN本身有两个非同寻常的特点。首先,任何涉及NaN的操作(例如NaN/10)都会返回NaN,这个特点在多步计算中有可能导致问题。其次,NaN与任何值都不相等,包括NaN本身。例如,下面的代码会返回false。
alert(NaN == NaN); //false
  JavaScript中有一个isNaN()函数,这个函数接受一个参数,该参数可以使任何类型,而函数会帮我们确定这个参数是否“不是数值”。isNaN()在接收一个值之后,会尝试将这个值转换为数值。某些不是数值的值会直接转换为数值,例如字符串”10“或Boolean值。而任何不能被转换为数值的值都会导致这个函数返回true。例如: