Javascript中的方法和匿名方法实例详解


Posted in Javascript onJune 13, 2015

本文实例讲述了Javascript中的方法和匿名方法。分享给大家供大家参考。具体分析如下:

Javascript方法(函数)

声明函数

以function开头,后跟函数名,与C#、java不同,Javascript不需要声明返回值类型、参数类型。没有返回值就是undefined。

举个例子更清楚: 
无参数无返回值的方法:

function f1(){
alert('这是一个方法');
}
f1();//调用方法

无参数有返回值的方法:

function f2(){
return 100;
}
var result=f2();//声明一个变量,接收f1()中的返回值
alert(result);//100

有参数有返回值的方法:

function f3(n1,n2){
return n1+n2;
}
var result=f3(20,30);
alert(result);//50

注意1:

先看例子:

function f1(){
  alert('这是一个方法'); 
}
alert(f1());//弹出”这是一个方法”后,还会显示undefined

原因:js中,变量没有赋值,就是undefined;该栗中f1()没有返回值,那么就是一个未知的值(undefined),这里未知的变量放入alert(),当然弹出的就是undefined

注意2:

alert(f1);//不写括号,会将f1整个代码以字符串形式显示出来:
function f1(){ 
alert('这是一个方法'); 
}

JavaScript中没有方法重载

只调用最新定义的方法:

function f1(n1,n2){ 
alert(n1+n2); 
} 
function f1(n1,n2){ 
alert(n1-n2); 
} 
f1(10,2);//8

结论:无论在哪里调用,都只调用最新定义的方法。

注意:数字+undefined=undefined

function f1(n1,n2,n3){ 
alert(n1-n2+n3); 
} 
f1(10,2);
//NaN,因为没有给n3传值,n3就是undefined,
//数字加上undefined还是undefined

以上结论:Javascript中没有方法重载

定义方法时注意:

自定义函数名不要和内置方法重名:
不要和js内置、dom内置方法重名,比如selectAll、focus等函数名不要用。

不要与系统函数重名。(在单击事件中调用自己定义的focus方法,有问题。与系统的focus()方法重名了)

书写规则括号注意:

一般在js中编写大括号都是直接跟在后面

function f1(){ 
return 
{ 
age:100}; 
} 
var s=f1(); 
alert(s.age);
//undefined。s结果是undefined,undefined.age必然还是undefined

匿名方法(用的非常多)

为什么推荐用匿名方法?

1、有一个1.js中有个方法function aa(){alert{'我挺帅了'}}

2、有一个2.js中有个方法function aa(){alert{'我越来越帅了'}}

3、将1.js和2.js依次导入到index.html中,调用aa();结果显示:我越来越帅了。

结论:2.js中的aa()方法会覆盖1.js中的aa()

怎么办?不再指定方法名,使用匿名方法

先看一个将匿名方法赋给变量例子:

var ff=function(n1,n2){ 
return n1+n2; 
}; 
alert(ff(20,30));//50

一行写完匿名方法:

(function (n1,n2){alert(n1+n2);})(9,9);

小案例:1:

var x=1; 
var y=0; 
var z=0; 
var add=function (n){n=n+1;return n}; 
y=add(x);//结果是2,先调用上面add 
add=function(n){n=n+3;return n;}; 
z=add(x);//结果是4,调用上面临近的这个add 
alert(y+','+z);//2,4

小案例2:

function aa() 
{ 
  alert("aaa"); 
  return function(){alert("bbb");}; 
} 
alert(aa);//不写括号,会将aa方法的整个代码显示出来 
alert(aa());//aaa,function(){alert("bbb");}; aaa就不解释了,后面那一串是作为aa()的返回值显示 
alert(aa()());//aaa,bbb,undefined 
//下面分解上面这句进行解释 
var s=aa();//aaa 
alert(s());//s()就是function(){alert("bbb");};首先弹出bbb,其次该方法没有返回值,故弹出undefined

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
jquery 回车事件实现代码
Aug 23 Javascript
JS动态增加删除UL节点LI及相关内容示例
May 21 Javascript
javascript工厂方式定义对象
Dec 26 Javascript
深入分析原生JavaScript事件
Dec 29 Javascript
JavaScript高级程序设计(第三版)学习笔记1~5章
Mar 11 Javascript
jQuery实现查找链接文字替换属性的方法
Jun 27 Javascript
jQuery实现为LI列表前3行设置样式的方法【2种方法】
Sep 04 Javascript
有关JS中的0,null,undefined,[],{},'''''''',false之间的关系
Feb 14 Javascript
H5手机端多文件上传预览插件
Apr 21 Javascript
在小程序中使用腾讯视频插件播放教程视频的方法
Jul 10 Javascript
VUE-cli3使用 svg-sprite-loader
Oct 20 Javascript
vue实现动态显示与隐藏底部导航的方法分析
Feb 11 Javascript
jquery实现简单的自动播放幻灯片效果
Jun 13 #Javascript
jquery实现简单手风琴菜单效果实例
Jun 13 #Javascript
jQuery实现的五子棋游戏实例
Jun 13 #Javascript
JavaScript合并两个数组并去除重复项的方法
Jun 13 #Javascript
JQuery自动触发事件的方法
Jun 13 #Javascript
JQuery中DOM实现事件移除的方法
Jun 13 #Javascript
JQuery中DOM事件冒泡实例分析
Jun 13 #Javascript
You might like
超级简单的发送邮件程序
2006/10/09 PHP
如何实现给定日期的若干天以后的日期
2006/10/09 PHP
SMARTY学习手记
2007/01/04 PHP
自己写了一个php检测文件编码的函数
2014/04/21 PHP
jQuery 入门讲解1
2009/04/15 Javascript
javascript实现设置、获取和删除Cookie的方法
2015/06/01 Javascript
javascript运算符语法全面概述
2016/07/14 Javascript
全面接触神奇的Bootstrap导航条实战篇
2016/08/01 Javascript
基于JS实现的随机数字抽签实例
2016/12/08 Javascript
详解angularJS动态生成的页面中ng-click无效解决办法
2017/06/19 Javascript
基于hover的用法实例(推荐)
2017/07/04 Javascript
vue iview实现动态路由和权限验证功能
2018/04/17 Javascript
解决vue 打包发布去#和页面空白的问题
2018/09/04 Javascript
Python中条件判断语句的简单使用方法
2015/08/21 Python
python抓取网页中图片并保存到本地
2015/12/01 Python
定制FileField中的上传文件名称实例
2017/08/23 Python
Python 数据处理库 pandas 入门教程基本操作
2018/04/19 Python
python批量读取文件名并写入txt文件中
2020/09/05 Python
对python中的*args与**kwgs的含义与作用详解
2019/08/28 Python
python基于event实现线程间通信控制
2020/01/13 Python
使用sklearn的cross_val_score进行交叉验证实例
2020/02/28 Python
django model的update时auto_now不被更新的原因及解决方式
2020/04/01 Python
Python Scrapy框架:通用爬虫之CrawlSpider用法简单示例
2020/04/11 Python
matplotlib绘制鼠标的十字光标的实现(自定义方式,官方实例)
2021/01/10 Python
html5的画布canvas——画出简单的矩形、三角形实例代码
2013/06/09 HTML / CSS
绢花、人造花和人造花卉:BLOOM
2019/08/07 全球购物
应届生英语教师求职信
2013/11/05 职场文书
理货员的岗位职责
2013/11/23 职场文书
个人求职信范文分享
2014/01/31 职场文书
董事长助理岗位职责
2014/02/18 职场文书
小学先进集体事迹材料
2014/05/31 职场文书
法人授权委托书
2014/09/16 职场文书
《我爱祖国》演讲稿1000字
2014/09/26 职场文书
办护照工作证明
2014/10/01 职场文书
岁月神偷观后感
2015/06/11 职场文书
Java Spring Lifecycle的使用
2022/05/06 Java/Android