一、JavaScript语言特点
1.1、JavaScript是基于对象和事件驱动的(动态的)
它可以直接对用户或客户输入做出响应,无须经过Web服务程序。它对用户的响应,是采用以事件驱动的方式进行的。所谓事件驱动,就是指在主页中执行了某种操作所产生的动作,就称为“事件”。比如按下鼠标,移动窗口,选择菜单等都可以视为事件。当事件发生后,可能会引起相应的事件响应。
1.2、JavaScript是跨平台的
JavaScript是依赖于浏览器本身的,与操作系统无关。
二、JavaScript变量
2.1、定义变量
在定义变量时,统一使用"var 变量名"表示,例如:var str;甚至可以省略var这个关键字
2.2、JavaScript变量的类型如何决定
JavaScript中变量的数据类型是由JS引擎决定的
var;//name是string类型 var age=;//age是number类型 var flag=true;//flag是boolean类型 var email;//email只是声明,没有赋值,因此代表的类型是"undefined",也就是无法确定 name=;//name自动变成了number类型
2.3、使用typeof关键字查看变量代表的具体数据类型
typeof 运算符有一个参数,即要检查的变量或值。例如:
var sTemp = "test string"; alert (typeof sTemp); //输出 "string" alert (typeof ); //输出 "number"
对变量或值调用typeof运算符将返回下列值之一:
undefined - 如果变量是 Undefined 类型的
boolean - 如果变量是 Boolean 类型的
number - 如果变量是 Number 类型的
string - 如果变量是 String 类型的
object - 如果变量是一种引用类型或 Null 类型的
测试代码:
<script type="text/javascript"> var;//name是string类型 alert("name是"+typeof name+"类型"); var age=;//age是number类型 alert("age是"+typeof age+"类型"); var flag=true;//flag是boolean类型 alert("flag的类型是:"+typeof flag); name=;//name自动变成了number类型 alert("name变量重新赋值后,name的数据类型变成了:"+typeof name); var email;//email只是声明,没有赋值,因此代表的类型是"undefined",也就是无法确定 alert("email的类型是:"+typeof email ); var a=null; /* 为什么 typeof 运算符对于 null 值会返回 "Object"。 这实际上是 JavaScript 最初实现中的一个错误,然后被 ECMAScript 沿用了。现在,null 被认为是对象的占位符,从而解释了这一矛盾,但从技术上来说,它仍然是原始值。 */ alert("a是"+typeof a +"类型"); </script>
运行结果:
三、JavaScript数据类型
JavaScript包含两种不同数据类型:基本数据类型和引用数据类型。基本类型指的是简单的数据,引用类型指由多个值构成的对象。当我们把值赋值给一个变量时,解析器首先要做的就是确认这个值是基本类型值还是引用类型值。
3.1、基本数据类型
常见的五种基本数据类型:
Boolean
Number
String
Undifined
Null
这五种基本数据类型可以直接操作保存在变量中的实际值。
3.1.1、数值类型(Number)和布尔类型(Boolean)
看下面的代码:
<script type="text/javascript"> var a = ; var b = a; b = ; alert("a="+a);//打印a= var b = true; var b = b; b = false; alert("b="+b);//打印b=true </script>
运行结果:
从运行结果可以看出,b的值是a值的一份拷贝,虽然,两个变量的值是相等,但是两个变量保存两不同的基本数据类型值。b只是保存了a复制的一个副本。所以,当b的值改变成20时,a的值依然是10。两个Boolean变量b1和b2同样是基本数据类型,同样保存两个不同的基本数据据类型值,b2保存1复制的一个副本。所以,当b2的值改变成false时,b1的值依然是true。
下图演示了这种基本数据类型赋值的过程:
栈内存
3.1.2、字符串类型(String)