• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

JavaScript程序基础十三匿名函数

武飞扬头像
看山还是山,看水还是水
帮助4

一、函数的定义
要把一段代码做成可重复使用的模块,需要掌握规定的格式:
function 函数名([参数 1, 参数 2,……]){
语句
[return 返回值]
}

普通函数示例:

function  fn(x){
      document.write(x   "<br />");
} 
fn("我爱学习JS");

函数定义时,如果没有函数名,可以吗?
答案是可以,但是必须按特定格式。
没有名字的函数,叫匿名函数

二、匿名函数

  1. 匿名函数的格式
    匿名函数:有关键字 function, 有小括号,有大括号,就是没有函数名。示例:
    function(参数1,参数2,……) {
    函数体
    }

    但是仅仅只有这些,并不完整。
    常见用法之一,用一个变量名记录匿名函数;用这个变量名代表函数名,按照函数调用格式使用。初步体验匿名函数:
    首先,用一个变量名记录匿名函数。
    然后,用这个变量名代表函数名,按照函数调用格式使用。
    var myfn=function(参数1,参数2,……) {
    函数体
    };

    匿名函数示例:
var printfn= function(x){
      document.write(x   "<br />");
} 
printfn ("我爱学习JS");

在网页中执行上面的代码,看效果。

但是,一般不推荐这种用法。

  1. 匿名函数用法(一)定义与执行合为一体
    匿名函数没有名字,要执行它,干脆不要名字,直接执行。
    语法格式:
    (function(参数1,参数2,……) {
    函数体
    })(参数1,参数2,……);

    示例:
(function(x) {
       document.write(x   “<br />”);
})(“我爱学习JS”);

一般推荐这种用法。

  1. 匿名函数用法(二)利用事件去调用匿名函数
    在事件中调用匿名函数,示例:
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
	</head>
	<body>
        <input type="button" id="mybtn" value="click me" />
		<script type="text/javascript">
			var  btn = document.getElementById("mybtn");  // 找到页面某个标签
			// 添加事件
			btn.onclick = function(){
			    alert("你点了我!");
			}
		</script>
	</body>
</html>
学新通

也推荐这种用法。
匿名函数还有两种用法:作为对象的方法调用、作为另一个函数的参数。大家可以自行查阅资料。

小结:
用途:通常不希望再次使用(即只使用一次的)的函数可以定义为匿名函数。
优点1:不用担心函数名冲突,方便在JS页面中添加功能。
优点2:创建匿名函数,由于外部无法引用它内部的变量,因此在执行完后很快就会被释放,这种机制不会污染全局对象。

三、实例训练

  1. 在网页中实现简单的加法计算,添加两个文本框和一个按钮,并给按钮点击事件添加匿名函数,计算求和结果。
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
	</head>
	<body>
        <input type="text" id="txt1" />
        <input type="text" id="txt2" />
        <input type="button" id="mybtn" value="加法" />
		<script type="text/javascript">
			var  btn = document.getElementById("mybtn"); 

			// 添加事件
			btn.onclick = function(){
			    var val1=document.getElementById("txt1").value;
			    var val2=document.getElementById("txt2").value;
			    alert(parseInt(val1) parseInt(val2));
			}
		</script>
	</body>
</html>
学新通

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhffhjha
系列文章
更多 icon
同类精品
更多 icon
继续加载