(1)数据类型列举
Numbers 数字类型
Strings 字符串类型
Booleans 布尔类型
Null 空
Undefined 未定义类型
Objects 对象类型
Arrays 数组类型
Date 日期类型
(2)Number 数字类型
JavaScript中只有一种数字类型。64位浮点数。遵循IEEE-754标准,类似于Java中的double类型。
语法
var x = 10 //整数
var x = 017 //八进制
var x = 0x16 //十六进制
var x = 3.14 //浮点数
var x = .33 //浮点数
注意事项:JS中浮点数运算,结果不精确。
示例代码
var a = 0.1;
var b = 0.2;
var result = a+b; //0.30000000000000004
(3)String 字符串类型
在JavaScript中没有字符类型。字符串可以使用双引号,也可以使用单引号。
语法
var s = “abcde”;
var s2 = ‘中文’;
获取字符串长度 length属性
var num = s.length;
字符串的一些函数
charAt //获取字符串某个位置的字符
concat //连接字符串
indexOf // 查找指定字符串在字符串中第一次出现的索引位置
lastIndexOf //倒叙查找指定字符串在字符串中第一次出现的索引位置
match //用来匹配正则表达式(查找符合规则的子串)
replace //替换字符串
split //分割字符串(结果是一个数组)
substring //截取子串
toLowerCase //转小写
toUpperCase //转大写
(4)Boolean 布尔类型
语法
var flag = true;
注:在做条件判断的逻辑运算时,其他数据类型可以自动转型为布尔类型。转型规则如下:(后面再演示,在这先看一下规则)
Number 非0 为true 0 为false
String 非空串 为true 空串为false ("" ‘’)
null false
undefined false
Object 不是null为true 是null为false
Arrays 不是null为true 是null为false
(5)Object 对象类型
JS中创建对象的方式有多种,在这里讲解一种最常用的方式。(json格式)
语法
var 对象名={
属性1:值,
属性2:值,
…
函数名:function(){
}
}
示例代码
var user = {
id:1,
name:‘王五’,
age:20,
sayHello:function(){
alert(“你好!!!”);
},
mutiply:function(a,b){
return a*b;
}
};
alert(user.id+"\t"+user.name+"\t"+user.age);
user.sayHello();
alert(user.mutiply(2,3));
(6)Array 数组类型
JS中的数组是动态数组。由于JS本身是一个弱类型的语言,数组中也可以同时存储多种类型的数据
定义方式
var aa1 = [1,3,9,10];
var aa2 = [4,6,“abc”,“ccc”,{x:1,y:2}];
使用下标访问数组中元素
alert(aa1[0]);
alert(aa1[1]);
…
alert(aa1[4]);
aa1[5] = 100;
alert(aa1[5]);
其他定义方式
var arr = new Array(10,11,68) // 由 10 11 68 组成的数组
var arr = new Array(10) //10个长度的数组,数组中还没有赋值
var arr = new Array(‘aaa’,‘ccc’,‘bbb’);
数组操作的函数
length //属性,获取数组长度
sort() //数组排序(默认升序)
sort(function(a,b){}) //传入排序规则
join() //把数组的元素组成字符串,默认使用,连接
join(“符号”) //用指定的符号连接
reverse() //数组翻转
push() //把元素存在数组末尾
pop() //取到数组的末尾元素,并移除数组中的这个元素
unshift() //把元素存在数组的开头
shift() //取到数组开头的元素,并移除数组中的这个元素
toString()
toLocaleString()
(7)Null 空类型
Null(空值)类型的值只有一个,就是null
null这个值专门用来表示一个为空的对象
(8)Undefined 未定义类型
Undefined类型只有一个特殊的值——undefined。undefined表示"缺少值",就是此处应该有一个值,但是还没有定义。
典型用法是:
1、变量被声明了,但没有赋值时,就等于undefined。
2、对象没有赋值的属性,该属性的值为undefined。
3、调用函数时,应该提供的参数没有提供,该参数等于undefined。
4、函数没有返回值时,默认返回undefined。
示例代码
var x = 100;
alert(x);
var y;
alert(y); // undefined
alert(z); // 报错, z is not defined
var user = {
id:1,
name:‘王五’,
age:20,
sayHello:function(){
alert(“你好!!!”);
},
mutiply:function(a,b){
return a*b;
}
};
alert(user.id);
alert(user.address); // undefined
function add(x,y){
alert(x+y);
}
add(“aaa”); // aaaundefined
function fun(){
}
var result = fun();
alert(result); // undefined
(9)Date 日期类型
JS中的Date 和 Java中一样,都是记录的距离 1970-01-01 零时的毫秒数
创建方式
var date = new Date(); //系统当前时间
var date = new Date(2000) //距离 1970-01-01 零时 2000毫秒
var date = new Date(“1990-10-10”); //IE8及之前版本不支持
var date = new Date(“1990/10/10”);
var date = new Date(“1990/10/10 11:11:11”);
var date = new Date(“August 6 1990 11:11:11”);
var date = new Date(1990,10,10,11,11,11); //月份是 0到11
日期运算
var d1 = new Date(“1990/10/10”);
var d2 = new Date(“1991/10/10”);
alert(d2-d1); 算出的是两个日期之间的毫秒数
Date的函数
setDate 设置 Date 对象中月份中的天数,其值介于 1 至 31 之间。
setHours 设置 Date 对象中的小时数,其值介于 0 至 23 之间。
setMinutes 设置 Date 对象中的分钟数,其值介于 0 至 59 之间。
setSeconds 设置 Date 对象中的秒数,其值介于 0 至 59 之间。
setTime 设置 Date 对象中的时间值。
setMonth 设置 Date 对象中的月份,其值介于 0 至 11 之间。
setYear
getDate 返回 Date 对象中月份中的天数,其值介于 1 至 31 之间
getDay 返回 Date 对象中的星期几,其值介于 0 至 6 之间
getHours 返回 Date 对象中的小时数,其值介于 0 至 23 之间
getMinutes 返回 Date 对象中的分钟数,其值介于 0 至 59 之间
getSeconds 返回 Date 对象中的秒数,其值介于 0 至 59 之间
getMonth 返回 Date 对象中的月份,其值介于 0 至11 之间
getFullYear 返回 Date 对象中的年份,其值为四位数
getTime 返回自某一时刻(1970 年 1 月 1 日)以来的毫秒数
toGMTString 使用格林尼治标准时间 (GMT) 数据格式将 Date 对象转换成字符串表示
toLocaleString 使用当地时间格式将 Date 对象转换成字符串表示
toLocaleDateString,按照本地格式显示一个日期对象的日期部分
toLocaleTimeString,按照本地格式显示一个日期对象的时间部分