js自学(2)--方法

方法是一段可以被重复执行多次的代码块。方法可以有参数,或者不带参数,可以有返回值,也可以没有返回值。

方法可以有很多种方法进行声明,以下我们列出了两种,一种是方法声明,一种是带命名的方法表达式。

方法声明:

 
 
  1. function foo() {
  2. // 执行代码
  3. }

带命名的方法表达式:

 
 
  1. var foo = function() {
  2. // 执行代码
  3. };

方法的调用 

以下示例是一个简单的方法使用,greet方法包括两个传参,没有返回值。

 
 
  1. var greet = function( person, greeting ) {
  2. var text = greeting + ", " + person;
  3. console.log( text );
  4. };
  5. greet( "极客", "你好" ); // "你好, 极客"

以下示例是一个有返回值的方法:

 
 
  1. var greet = function( person, greeting ) {
  2. var text = greeting + ", " + person;
  3. return text;
  4. };
  5. console.log( greet( "极客", "你好" ) ); // "你好, 极客"

 下面这个例子中的方法,返回值是另一个方法。

 
 
  1. var greet = function( person, greeting ) {
  2. var text = greeting + ", " + person;
  3. return function() {
  4. console.log( text );
  5. };
  6. };
  7. var greeting = greet( "极客", "你好" );
  8. greeting(); // "你好, 极客"

上面方法调用的几个示例,你可以在下面自己试验一下,在下面这个演示中,我们仿照上面第二个示例定义了一个方法,点击按钮调用了我们预先定义的方法,从而填出提示框,并且在控制台打出相应的字符。你可以尝试按照上面的示例,改变一下方法的定义,然后再运行一下看看效果。

立即调用的方法表达(IIFE) 

立即调用的方法表达是JavaScript中一种常用的模式。这种模式创建方法,并且立即执行它。当你想避免你的方法影响全局命名空间时 - 即你不希望方法内的变量在全局可用,这种模式就显得尤为重要了。

 
 
  1. // IIFE (Immediately-invoked function expression)
  2. (function() {
  3. var foo = "你好,极客标签";
  4. })();
  5. console.log( foo ); // undefined!

以上代码中,我们看到控制台将打出undefined,因为foo这个变量是在function中定义的,而在方法外,我们是不能调用方法内定义的变量的。

方法作为参数

在JavaScript中,方法是“头等公民” - 他们可以分配变量,也可以作为参数传递到其他方法中去。在jQuery中,将方法作为参数传递是非常普遍的。

 
 
  1. // 传递匿名方法作为参数
  2. var myFn = function( fn ) {
  3. var result = fn();
  4. console.log( result );
  5. };
  6. // 控制台输出的结果
  7. myFn( function() {
  8. return "你好,极客标签";
  9. });

上面示例中,定义了一个myFn的方法,在控制台中打印出结果。而我们赋值的时候,是直接为myFn方法传入了一个匿名的方法,该匿名方法返回了一个字符串,这个字符串作为结果,最终输出到了控制台上。

 
 
  1. // 传入命名好的方法作为参数
  2. var myFn = function( fn ) {
  3. var result = fn();
  4. console.log( result );
  5. };
  6. var myOtherFn = function() {
  7. return "你好,极客标签";
  8. };
  9. myFn( myOtherFn ); // "你好,极客标签"

上面的示例中,我们将一个名为myOtherFn的方法作为参数传给了myFn,其效果和传入匿名方法是一样的,但是需要注意的是,在其他的地方,你仍旧可以使用myOtherFn方法,如果你需要多次重复使用这个方法,你还是应该为他命名,可以保证它被重复调用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值