文章目录
  1. 1. 前言
  2. 2. 事件响应,让网页交互
    1. 2.1. 点击事件
    2. 2.2. 鼠标经过事件(onmouseover)
    3. 2.3. 鼠标移开事件(onmouseout)
    4. 2.4. 光标聚焦事件(onfocus)
    5. 2.5. 失焦事件(onblur)
    6. 2.6. 内容选中事件(onselect)
    7. 2.7. 文本框内容改变事件(onchange)
    8. 2.8. 加载事件(onload)
    9. 2.9. 卸载事件(onunload)
  3. 3. JavaScript内置对象
    1. 3.1. Date 日期对象
    2. 3.2. 返回/设置年份方法
    3. 3.3. 返回星期方法
    4. 3.4. 返回/设置时间方法
  4. 4. String 字符串对象
    1. 4.1. 返回指定位置的字符
    2. 4.2. 返回指定的字符串首次出现的位置
    3. 4.3. 字符串分割split()
    4. 4.4. 提取字符串substring()
    5. 4.5. 提取指定数目的字符substr()
  5. 5. Math对象
    1. 5.1. 向上取整ceil()
    2. 5.2. 向下取整floor()
    3. 5.3. 四舍五入round()
    4. 5.4. 随机数 random()
  6. 6. Array 数组对象
    1. 6.1. 数组连接concat()
    2. 6.2. 指定分隔符连接数组元素join()
    3. 6.3. 颠倒数组元素顺序reverse()
    4. 6.4. 选定元素slice()
    5. 6.5. 数组排序sort()

前言

话不多说,走起

主要的事件列表

事件响应,让网页交互

点击事件

1
2

<input name="点击我" type="button" value="点击我" onclick ="openwin()"/>

鼠标经过事件(onmouseover)

1
2
3
4
5

<form>
密码:<input name="password" type="password" >
<input name="确定" type="button" value="确定"onmouseover = "message()"/>
</form>

密码:
<input name=”确定” type=”button” value=”确定”onmouseover = “message()”/>

鼠标移开事件(onmouseout)

1
2
3
4
5

<form>
<a href="https://lizhaojie001.github.io/" onmouseout="message()" >点击我</a>

</form>

点击我

光标聚焦事件(onfocus)

当网页中的对象获得聚点时,执行onfocus调用的程序就会被执行。

1
2
3
4
5
6
7
8
9
10

<form>
<select name="career" onfocus = "message()">
<option>学生</option>
<option>教师</option>
<option>工程师</option>
<option>演员</option>
<option>会计</option>
</select>
</form>


失焦事件(onblur)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
 
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title> 失焦事件 </title>
<script type="text/javascript">
function message(){
alert("请确定已输入密码后,在移开!"); }
</script>
</head>
<body>
<form>
用户:<input name="username" type="text" value="请输入用户名!" onblur="message()">
密码:<input name="password" type="text" value="请输入密码!" >
</form>
</body>
</html>



失焦事件




用户:
密码:


内容选中事件(onselect)

选中事件,当文本框或者文本域中的文字被选中时,触发onselect事件,同时调用的程序就会被执行。

1
2
3
 

<textarea name="summary" cols="60" rows="5">请写入个人简介,不少于200字!</textarea>

个人简介:

<textarea name=”summary” cols=”60” rows=”5”onselect = “message()”>请写入个人简介,不少于200字!

文本框内容改变事件(onchange)

通过改变文本框的内容来触发onchange事件,同时执行被调用的程序。

1
2
3
4
<form>
个人简介:<br>
<textarea name="summary" cols="60" rows="5"onchange="message()">请写入个人简介,不少于200字!</textarea>
</form>

个人简介:

<textarea name=”summary” cols=”60” rows=”5”onchange=”message()”>请写入个人简介,不少于200字!

加载事件(onload)

事件会在页面加载完成后,立即发生,同时执行被调用的程序。
注意:

  1. 加载页面时,触发onload事件,事件写在标签内。
  2. 此节的加载页面,可理解为打开一个新页面时。
    如下代码,当加载一个新页面时,弹出对话框“加载中,请稍等…”。
1
2
3
4

<body onload="message()">
欢迎学习JavaScript。
</body>

欢迎学习JavaScript。

卸载事件(onunload)

当用户退出页面时(页面关闭、页面刷新等),触发onUnload事件,同时执行被调用的程序。

注意:不同浏览器对onunload事件支持不同。

1
2
3
4
 
<body onunload ="message()">
欢迎学习JavaScript。
</body>

欢迎学习JavaScript。

JavaScript内置对象

Date 日期对象

1
2
var d = new Date(2012, 10, 1);  //2012年10月1日
var d = new Date('Oct 1, 2012'); //2012年10月1日

返回/设置年份方法

1
get/setFullYear() 返回/设置年份,用四位数表示。
1
2
3
4
5
6

var mydate=new Date();//当前时间2014年3月6日
document.write(mydate+"<br>");//输出当前时间
document.write(mydate.getFullYear()+"<br>");//输出当前年份
mydate.setFullYear(81); //设置年份
document.write(mydate+"<br>"); //输出年份被设定为 0081年。

结果:

1
2
3
**Thu Mar 06 2014 10:57:47 GMT+0800
2014
Thu Mar 06 0081 10:57:47 GMT+0800**

注意

  1. 结果格式依次为:星期、月、日、年、时、分、秒、时区。(火狐浏览器)

  2. 不同浏览器,时间格式有差异。

返回星期方法

1
2
3
4
5
6
7
8
 <script type="text/javascript">
var mydate=new Date();//定义日期对象
var weekday=["星期日","星期一","星期二","星期三","星期四","星期五","星期六"];
//定义数组对象,给每个数组项赋值
var mynum=mydate.getDay();//返回值存储在变量mynum中
document.write(mydate.getDay());//输出getDay()获取值
document.write("今天是:"+ weekday[mynum]);//输出星期几
</script>

返回/设置时间方法

get/setTime() 返回/设置时间,单位毫秒数,计算从 1970 年 1 月 1 日零时到日期对象所指的日期的毫秒数。

如果将目前日期对象的时间推迟1小时,代码如下:

1
2
3
4
5
6
7

<script type="text/javascript">
var mydate=new Date();
document.write("当前时间:"+mydate+"<br>");
mydate.setTime(mydate.getTime() + 60 * 60 * 1000);
document.write("推迟一小时时间:" + mydate);
</script>

结果:

1
2
3
当前时间:Thu Mar 6 11:46:27 UTC+0800 2014

推迟一小时时间:Thu Mar 6 12:46:27 UTC+0800 2014

注意:

  1. 一小时 60 分,一分 60 秒,一秒 1000 毫秒
  2. 时间推迟 1 小时,就是: “x.setTime(x.getTime() + 60 60 1000);”

String 字符串对象

属性:length长度 toUpperCase()转大写 toLowerCase()转小写

返回指定位置的字符

charAt() 方法可返回指定位置的字符。返回的字符是长度为 1 的字符串。

语法:

1
2

stringObject.charAt(index)

注意:

  1. 字符串中第一个字符的下标是 0。最后一个字符的下标为字符串长度减一(string.length-1)。

  2. 如果参数 index 不在 0 与 string.length-1 之间,该方法将返回一个空字符串。

如:在字符串 “I love JavaScript!” 中,返回位置2的字符:

1
2
3
4
5

<script type="text/javascript">
var mystr="I love JavaScript!"
document.write(mystr.charAt(2));
</script>

注意:
一个空格也算一个字符。

以上代码的运行结果:

1
2

l

返回指定的字符串首次出现的位置

indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。

语法

1
stringObject.indexOf(substring, startpos)

参数说明:

说明:

  1. 该方法将从头到尾地检索字符串 stringObject,看它是否含有子串 substring。

  2. 可选参数,从stringObject的startpos位置开始查找substring,如果没有此参数将从stringObject的开始位置查找。

  3. 如果找到一个 substring,则返回 substring 的第一次出现的位置。stringObject 中的字符位置是从 0 开始的。

注意:

  1. indexOf() 方法区分大小写。

  2. 如果要检索的字符串值没有出现,则该方法返回 -1。

例如: 对 “I love JavaScript!” 字符串内进行不同的检索:

1
2
3
4
5
6
7

<script type="text/javascript">
var str="I love JavaScript!"
document.write(str.indexOf("I") + "<br />");
document.write(str.indexOf("v") + "<br />");
document.write(str.indexOf("v",8));
</script>

以上代码的输出:

1
2
3
0
4
9

字符串分割split()

split() 方法将字符串分割为字符串数组,并返回此数组。

语法:

1
stringObject.split(separator,limit)

参数说明:

注意:如果把空字符串 (“”) 用作 separator,那么 stringObject 中的每个字符之间都会被分割。

我们将按照不同的方式来分割字符串:

使用指定符号分割字符串,代码如下:

1
2
3
4

var mystr = "www.imooc.com";
document.write(mystr.split(".")+"<br>");
document.write(mystr.split(".", 2)+"<br>");

运行结果:

1
2
3

www,imooc,com
www,imooc

将字符串分割为字符,代码如下:

1
2
document.write(mystr.split("")+"<br>");
document.write(mystr.split("", 5));

运行结果:

1
2
w,w,w,.,i,m,o,o,c,.,c,o,m
w,w,w,.,i

提取字符串substring()

substring() 方法用于提取字符串中介于两个指定下标之间的字符。

语法:

1
stringObject.substring(starPos,stopPos)

参数说明:

注意:

  1. 返回的内容是从 start开始(包含start位置的字符)到 stop-1 处的所有字符,其长度为 stop 减start。

  2. 如果参数 start 与 stop 相等,那么该方法返回的就是一个空串(即长度为 0 的字符串)。

  3. 如果 start 比 stop 大,那么该方法在提取子串之前会先交换这两个参数。

使用 substring() 从字符串中提取字符串,代码如下:

1
2
3
4
5
<script type="text/javascript">
var mystr="I love JavaScript";
document.write(mystr.substring(7));
document.write(mystr.substring(2,6));
</script>

运行结果:

1
2
JavaScript
love

提取指定数目的字符substr()

substr() 方法从字符串中提取从 startPos位置开始的指定数目的字符串。

语法:

1
stringObject.substr(startPos,length)

参数说明:

注意:如果参数startPos是负数,从字符串的尾部开始算起的位置。也就是说,-1 指字符串中最后一个字符,-2 指倒数第二个字符,以此类推。

如果startPos为负数且绝对值大于字符串长度,startPos为0。

使用 substr() 从字符串中提取一些字符,代码如下:

1
2
3
4
5
<script type="text/javascript">
var mystr="I love JavaScript!";
document.write(mystr.substr(7));
document.write(mystr.substr(2,4));
</script>

运行结果:

1
2
JavaScript!
love

Math对象

Math对象,提供对数据的数学计算。

使用 Math 的属性和方法,代码如下:

1
2
3
4
5
6
<script type="text/javascript">
var mypi=Math.PI;
var myabs=Math.abs(-15);
document.write(mypi);
document.write(myabs);
</script>

运行结果:

1
2
3.141592653589793
15

注意:Math 对象是一个固有的对象,无需创建它,直接把 Math 作为对象使用就可以调用其所有属性和方法。这是它与Date,String对象的区别。

Math 对象属性

向上取整ceil()

ceil() 方法可对一个数进行向上取整。

语法:

1
Math.ceil(x)

参数说明:

注意:它返回的是大于或等于x,并且与x最接近的整数。

我们将把 ceil() 方法运用到不同的数字上,代码如下:

1
2
3
4
5
6
7
8
<script type="text/javascript">
document.write(Math.ceil(0.8) + "<br />")
document.write(Math.ceil(6.3) + "<br />")
document.write(Math.ceil(5) + "<br />")
document.write(Math.ceil(3.5) + "<br />")
document.write(Math.ceil(-5.1) + "<br />")
document.write(Math.ceil(-5.9))
</script>

运行结果:

1
2
3
4
5
6
1
7
5
4
-5
-5

向下取整floor()

floor() 方法可对一个数进行向下取整。

语法:

1
Math.floor(x)

参数说明:

注意:返回的是小于或等于x,并且与 x 最接近的整数。

我们将在不同的数字上使用 floor() 方法,代码如下:

1
2
3
4
5
6
7
8
<script type="text/javascript">
document.write(Math.floor(0.8)+ "<br>")
document.write(Math.floor(6.3)+ "<br>")
document.write(Math.floor(5)+ "<br>")
document.write(Math.floor(3.5)+ "<br>")
document.write(Math.floor(-5.1)+ "<br>")
document.write(Math.floor(-5.9))
</script>

运行结果:

1
2
3
4
5
6
0
6
5
3
-6
-6

四舍五入round()

round() 方法可把一个数字四舍五入为最接近的整数。

语法:

1
Math.round(x)

参数说明:

注意:

  1. 返回与 x 最接近的整数。

  2. 对于 0.5,该方法将进行上舍入。(5.5 将舍入为 6)

  3. 如果 x 与两侧整数同等接近,则结果接近 +∞方向的数字值 。(如 -5.5 将舍入为 -5; -5.52 将舍入为 -6),如下图:

把不同的数舍入为最接近的整数,代码如下:

1
2
3
4
5
6
7
<script type="text/javascript">
document.write(Math.round(1.6)+ "<br>");
document.write(Math.round(2.5)+ "<br>");
document.write(Math.round(0.49)+ "<br>");
document.write(Math.round(-6.4)+ "<br>");
document.write(Math.round(-6.6));
</script>

运行结果:

1
2
3
4
5
2
3
0
-6
-7

随机数 random()

random() 方法可返回介于 0 ~ 1(大于或等于 0 但小于 1 )之间的一个随机数。
语法:

1
Math.random();

注意:返回一个大于或等于 0 但小于 1 的符号为正的数字值。

我们取得介于 0 到 1 之间的一个随机数,代码如下:

1
2
3
<script type="text/javascript">
document.write(Math.random());
</script>

运行结果:

1
0.190305486195328

注意:因为是随机数,所以每次运行结果不一样,但是0 ~ 1的数值。
获得0 ~ 10之间的随机数,代码如下:

1
2
3
<script type="text/javascript">
document.write((Math.random())*10);
</script>

运行结果:

1
8.72153625893887

Array 数组对象

数组定义的方法:

  1. 定义了一个空数组:

    1
    var  数组名= new Array();
  2. 定义时指定有n个空元素的数组:

    1
    var 数组名 =new Array(n);

3.定义数组的时候,直接初始化数据:

1
var  数组名 = [<元素1>, <元素2>, <元素3>...];

我们定义myArray数组,并赋值,代码如下:

1
var myArray = [2, 8, 6];

说明:定义了一个数组 myArray,里边的元素是:myArray[0] = 2; myArray[1] = 8; myArray[2] = 6。

数组元素使用:

1
数组名[下标] = 值;

注意: 数组的下标用方括号括起来,从0开始。

数组属性:

数组连接concat()

concat() 方法用于连接两个或多个数组。此方法返回一个新数组,不改变原来的数组。

语法

1
arrayObject.concat(array1,array2,...,arrayN)

参数说明:

注意: 该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。

我们创建一个数组,将把 concat() 中的参数连接到数组 myarr 中,代码如下:

1
2
3
4
5
6
7
8
<script type="text/javascript">
var mya = new Array(3);
mya[0] = "1";
mya[1] = "2";
mya[2] = "3";
document.write(mya.concat(4,5)+"<br>");
document.write(mya);
</script>

运行结果:

1
2
1,2,3,4,5
1,2,3

我们创建了三个数组,然后使用 concat() 把它们连接起来,代码如下:

1
2
3
4
5
6
7
<script type="text/javascript">
var mya1= new Array("hello!")
var mya2= new Array("I","love");
var mya3= new Array("JavaScript","!");
var mya4=mya1.concat(mya2,mya3);
document.write(mya4);
</script>

运行结果:

1
hello!,I,love,JavaScript,!

指定分隔符连接数组元素join()

join()方法用于把数组中的所有元素放入一个字符串。元素是通过指定的分隔符进行分隔的。

语法:

1
arrayObject.join(分隔符)

参数说明:

注意:返回一个字符串,该字符串把数组中的各个元素串起来,用<分隔符>置于元素与元素之间。这个方法不影响数组原本的内容。 我们使用join()方法,将数组的所有元素放入一个字符串中,代码如下:

1
2
3
4
5
6
7
<script type="text/javascript">
var myarr = new Array(3);
myarr[0] = "I";
myarr[1] = "love";
myarr[2] = "JavaScript";
document.write(myarr.join());
</script>

运行结果:

1
I,love,JavaScript

我们将使用分隔符来分隔数组中的元素,代码如下:

1
2
3
4
5
6
7
<script type="text/javascript">
var myarr = new Array(3)
myarr[0] = "I";
myarr[1] = "love";
myarr[2] = "JavaScript";
document.write(myarr.join("."));
</script>

运行结果:

1
I.love.JavaScript

颠倒数组元素顺序reverse()

reverse() 方法用于颠倒数组中元素的顺序。

语法:

1
arrayObject.reverse()

注意:该方法会改变原来的数组,而不会创建新的数组。

定义数组myarr并赋值,然后颠倒其元素的顺序:

1
2
3
4
5
6
7
8
<script type="text/javascript">
var myarr = new Array(3)
myarr[0] = "1"
myarr[1] = "2"
myarr[2] = "3"
document.write(myarr + "<br />")
document.write(myarr.reverse())
</script>

运行结果:

1
2
1,2,3
3,2,1

选定元素slice()

slice() 方法可从已有的数组中返回选定的元素。

语法

1
arrayObject.slice(start,end)

参数说明:

  1. 返回一个新的数组,包含从 start 到 end (不包括该元素)的 arrayObject 中的元素。

  2. 该方法并不会修改数组,而是返回一个子数组。

注意:

  1. 可使用负值从数组的尾部选取元素。

  2. 如果 end 未被规定,那么 slice() 方法会选取从 start 到数组结尾的所有元素。

  3. String.slice() 与 Array.slice() 相似。

我们将创建一个新数组,然后从其中选取的元素,代码如下:

1
2
3
4
5
6
<script type="text/javascript">
var myarr = new Array(1,2,3,4,5,6);
document.write(myarr + "<br>");
document.write(myarr.slice(2,4) + "<br>");
document.write(myarr);
</script>

运行结果:

1
2
3
1,2,3,4,5,6
3,4
1,2,3,4,5,6

数组排序sort()

sort()方法使数组中的元素按照一定的顺序排列。

语法:

1
arrayObject.sort(方法函数)

参数说明:

  1. 如果不指定<方法函数>,则按unicode码顺序排列。

  2. 如果指定<方法函数>,则按<方法函数>所指定的排序方法排序。

myArray.sort(sortMethod);

注意: 该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

若返回值<=-1,则表示 A 在排序后的序列中出现在 B 之前。
若返回值>-1 && <1,则表示 A 和 B 具有相同的排序顺序。
若返回值>=1,则表示 A 在排序后的序列中出现在 B 之后。

  1. 使用sort()将数组进行排序,代码如下:
1
2
3
4
5
6
<script type="text/javascript">
var myarr1 = new Array("Hello","John","love","JavaScript");
var myarr2 = new Array("80","16","50","6","100","1");
document.write(myarr1.sort()+"<br>");
document.write(myarr2.sort());
</script>

运行结果:

1
2
Hello,JavaScript,John,love
1,100,16,50,6,80

注意:上面的代码没有按照数值的大小对数字进行排序。

  1. 如要实现这一点,就必须使用一个排序函数,代码如下:
1
2
3
4
5
6
7
8
9
<script type="text/javascript">
function sortNum(a,b) {
return a - b;
//升序,如降序,把“a - b”该成“b - a”
}
var myarr = new Array("80","16","50","6","100","1");
document.write(myarr + "<br>");
document.write(myarr.sort(sortNum));
</script>

运行结果:

1
2
80,16,50,6,100,1
1,6,16,50,80,100

编程测试

文章目录
  1. 1. 前言
  2. 2. 事件响应,让网页交互
    1. 2.1. 点击事件
    2. 2.2. 鼠标经过事件(onmouseover)
    3. 2.3. 鼠标移开事件(onmouseout)
    4. 2.4. 光标聚焦事件(onfocus)
    5. 2.5. 失焦事件(onblur)
    6. 2.6. 内容选中事件(onselect)
    7. 2.7. 文本框内容改变事件(onchange)
    8. 2.8. 加载事件(onload)
    9. 2.9. 卸载事件(onunload)
  3. 3. JavaScript内置对象
    1. 3.1. Date 日期对象
    2. 3.2. 返回/设置年份方法
    3. 3.3. 返回星期方法
    4. 3.4. 返回/设置时间方法
  4. 4. String 字符串对象
    1. 4.1. 返回指定位置的字符
    2. 4.2. 返回指定的字符串首次出现的位置
    3. 4.3. 字符串分割split()
    4. 4.4. 提取字符串substring()
    5. 4.5. 提取指定数目的字符substr()
  5. 5. Math对象
    1. 5.1. 向上取整ceil()
    2. 5.2. 向下取整floor()
    3. 5.3. 四舍五入round()
    4. 5.4. 随机数 random()
  6. 6. Array 数组对象
    1. 6.1. 数组连接concat()
    2. 6.2. 指定分隔符连接数组元素join()
    3. 6.3. 颠倒数组元素顺序reverse()
    4. 6.4. 选定元素slice()
    5. 6.5. 数组排序sort()