1.JavaScript
a.定义:JavaScript 是脚本语言,是一种轻量级的编程语言
b.实现:①直接通过标签里面的onXX属性驱动js的执行
<input type="button" value="测试" onclick="alert('hello')">
②引入外部js文件——JavaScript File
<script src="my.js"></script>
③可被放置在 HTML 页面的 <body> 和 <head> 部分中
<script type="text/javascript">
alert("script");
</script>
2.数据类型:
a.数据类型:字符串(String)、数字(Number)、布尔(Boolean)、数组(Array)、对象(Object)、Null、Undefined
var num = 1;
var str = "hello";
var flag = true;
var str1;
注:加了var声明变量,代表的是局部变量,不加则代表的是全局变量
b.通过 new Number 可以进行与字符串和布尔的转换:
var num = new Number(1);
var num = new Number(true); //结果为1
var num = new Number("12"); //如果字符串不为数字,则结果为NaN
c.通过 new String 可以进行与数字和布尔的转换:
var str = new String("hello");
var str = new String(12);
var str = new String(ture); //结果为true
d.通过 new Boolean 可以进行与数字和字符串的转换:
var flag = new Boolean("123"); //非空为真
var flag = new Boolean(2); //非0为真
注:字符串:“”空为false,非空为true
数字:非0为true,0为false
e.null 与 undefined 的区别:
①undefined :声明了变量并未初始化
②null:当在文档中找不到这个元素的时候
f.对象(Object):
①初始化:
//对象初始化方式一:
var person = {
userName:"张三",
userPwd:"123",
userAge:18
}
//对象初始化方式二:
var user = new Object();
user.userName = "李四";
user.userAge = 18;
②属性访问:
//对象的属性访问方式一: 对象名.属性名;
alert(user.userName);
//对象的属性访问方式二: 对象名["属性名"];
alert(user["属性名"]);
g.数组
声明:
var array = new Array(); //声明方式一
var array = new Array(3);
var nums = [1,2,"张三"]; //声明方式二
var strs = new Array("张三","李四"); //声明方式三
var strs = new Array(new Number(2));
3.运算符
a.算数运算符:+ - * / % ++ --
b.赋值运算符:+= -= *= /= %=
c.比较运算符:== === > < >= <= !=
①===:表示类型和值都一样
②==:表示值一样
在js中字符串的比较一般用==来代替.equal
d.逻辑运算符:&& || !
e.三目运算符:
var num = 判断表达式 ? 真执行表达式 : 假执行表达式
4.判断语句:if-else switch
5.循环语句:while do-while for for-each
for(i = 0; i < 100; i++){
alert(i);
}
for(index in names){
document.write(names[xindex]);
}
6.方法
a.声明:
function test(a,b){ //声明方式一
return a+b;
}
var test1 = function(){ //声明方式二
}
var test2 = new Function( function (){ //声明方式三
})
注:函数默认返回值未定义(undefined)
函数如果需要返回值,直接return
b.访问:
test();
7.String (String的方法与Java类似,详见API)
str.substr(1,3) //截取从下标为1的元素开始取3个
str.substring(1,3) //截取下标1到2的元素(前闭后开)
注:js字符串的length是属性,而java中是方法
8.时间(Date)
var date = new Date(); //声明
var date = new Date("2015/01/01");
getDay(); //一周的第几天(0-6)
getDate(); //一月的第几天(1-31)
getMonth(); //月份(0-11)
getFullYear(); //以四位数字返回年份
getHours(); //小时 (0 ~ 23)
getMinutes(); //分钟 (0 ~ 59)
getSeconds(); //秒数 (0 ~ 59)
getMilliseconds(); //毫秒(0 ~ 999)
getTime(); //返回1970年1月1日至今的毫秒数
Date.parse("2015/01/01"); //指定日期的毫秒数
9.数学(Math)(方法与Java类似,详见API)
10.全局函数
isNaN(); //检查某个值是否是数字
Number(); //把对象的值转换为数字
String(); //把对象的值转换为字符串
parseInt(); //解析一个字符串并返回一个整数
parseFloat(); //解析一个字符串并返回一个实数
eval(); //计算 JavaScript 字符串,并把它作为脚本代码来执行
11.事件(Events)
a.UI相关:onload、onunload、onresize、onselect
b.焦点相关:onblur、onfocus
c.鼠标与滚轮相关:onclick、ondblclick、onmousedown、onmousemove、onmouseout、onmouseover、onmouseup
d.键盘相关:onkeydown、onkeyup、onkeypress
e.其他:onabord、onchange
12.正则表达式(RexExp)
var regex = /^[a-z]$/ g; ///pattern/attributes
var regex = new RegExp ("[a-z]","g"); //new RegExp(pattern, attributes);
regex.text(str); //检索字符串中指定的值。返回 true 或 false
regex.exec(str); //检索字符串中指定的值。返回找到的值,并确定其位置
注:str.match(regex);
返回的是根据正则表达式匹配的结果
如果全局匹配,返回的是数组
如果没有匹配成功,则返回null