1、return详解及应用
return: 返回值
return 后面可以跟 数字(100)、字符串("miaov")、布尔、函数、对象(元素、[]、{} 、null)、未定义
(1) 函数名 + 括号 : fn1() => return 后面的值
(2) return 后面任何代码都不执行
function fn2() {
return 'miaov'
alert(520) // return 后面任何代码都不执行
}
alert(fn2()); // miaov
2、arguments实参集合与局部变量、参数关系
当函数的参数无法确定的时候,用:arguments
arguments 一般与 return 连用
function sum() { // 累加器
var n = 0
for (var i = 0; i < arguments.length; i++) {
n += arguments[i];
}
return n;
}
alert(sum(1,2,3)) // 6
alert(sum(1,2,3,4)) // 10
3、定时器管理
开启定时器:
setInterval 【间隔性】一旦启动就不会停下来
setTimeout【延时性】只执行一次
setInterval(fnTime,1000); // 调用函数不写 括号
停止定时器:
clearInterval
clearTimeout
3.1、setInterval详解、倒计时+轮播图 实例
SetInterval("function",time)
'【间隔性定时器】 一旦启动就不会停下来(A,1000)'
SetInterval 该"函数"每隔一段时间,就执行一次。SetInterval会自动重复。
3.2、setTimeout详解、弹窗广告+延时提示框 实例
setTimeout("function",time)
'【延时性定时器】只执行一次(A,1000)'
setTimeout 该"函数"延迟一段时间,再进行某项操作。setTimeout不会重复。
3.3、停止定时器
clearTimeout(对象) 清除已设置的setTimeout对象
clearInterval(对象) 清除已设置的setInterval对象
setInterval小案例:背景选择实例
<html lang="en">
<head>
<meta charset="UTF-8">
</head>
<body>
<input type="button" value="自动切换图片">
<input type="button" value="停止">
<br>
<img src="" width="300" alt="">
<script type="text/javascript">
var aBtn = document.getElementsByTagName('input');
var oImg = document.getElementsByTagName('img')[0];
var arrUrl = ['img/1.jpg','img/2.jpg','img/3.jpg','img/4.jpg'];
var num = 0;
var timer = null;
aBtn[0].onclick = function () {
clearInterval(timer) // 防流氓、每次点击都清除一次旧的定时器
timer = setInterval(function () {
oImg.src = arrUrl[num];
num ++;
num %= arrUrl.length;
},1000)
}
aBtn[1].onclick = function () {
clearInterval(timer);
}
</script>
</body></html>
setTimeout小案例:弹窗广告
<html lang="en">
<head>
<meta charset="UTF-8">
<style media="screen">
#img {width: 518px; height: 345px; margin: 100px auto;}
img { width: 518px; display: none;}
</style>
</head>
<body>
<div id="img"><img src="img/1.jpg"alt=""></div>
<script type="text/javascript">
var oImg = document.getElementsByTagName('img')[0]
setTimeout(function () {
oImg.style.display = 'block'
setTimeout(function () {
oImg.style.display = 'none'
},2000);
},3000);
</script>
</body></html>