实践与提高:js匿名函数与this变量在不同作用域的追踪

JavaScript匿名函数,在开源软件、插件中大量存在,主要用于初始化对象、实现一个框架;对于习惯了函数常规写法,初次阅读这样的源代码,有点晕,其实,看到最简单的匿名函数原型后,感觉就这么简单。这个实例是对这一用法的小结,有以下几个知识点:

  1. 一个最简单的匿名函数原型,
  2. 带对象作参数的匿名函数,
  3. 使用for/in结构遍历对象属性或子对象,
  4. 对this变量在不同的作用域进行追踪。

<!--
胡开明
实践与提高:js匿名函数与this变量
-->
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
    <head>
        <title>js匿名函数与this变量</title>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

        <script type="text/javascript">
            //最简单的匿名函数
            (function(){
                var s="匿名函数";
                alert(s);
            })();//定义匿名函数并调用该匿名函数

        </script>

        <script type="text/javascript">
            //var record={id:"001",label:"javascript技术",price:89.50};
            //带参数的匿名函数
            (function(r){
                for(var i in r){alert(i+":"+r[i]);}//id:001、label:javascript技术、price:89.50
                var me=this;
                alert("this==me is : "+(this==me));//true
                var AboutThis={
                    f:function(){
                        alert("this==me is : "+(this==me));//false
                        alert("this==AboutThis is : "+(this==AboutThis));//true
                        alert("this==AboutThis.f is : "+(this==AboutThis.f));//false
                        AboutThis.f=this;
                        alert("this==AboutThis.f is : "+(this==AboutThis.f));//true
                    }
                };
                AboutThis.f();
                alert("this==me is : "+(this==me));//true
            })({id:"001",label:"javascript技术",price:89.50});
        </script>
    </head>
    <body>
        <h3>实践与提高:匿名函数与this变量</h3>
        <pre>
          匿名函数,在js第三方插件、开源软件中大量存在,主要用于初始化对象、实现一个框架;这个实例是对这一用法的小结。
        </pre>
    </body>
</html>


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值