Javascript构造函数注意事项

注意事项一

任何函数的构造函数都是Function
测试案例:

        <script type="text/javascript">
            function Foo(){}
            var foo = new Foo();
            console.log(foo.constructor);
            console.log(Foo.constructor);
            console.log(foo.constructor === Foo);
        </script>

输出结果
Foo(){}
Function() { [native code] }
true

输出结果分析
1、由Foo()函数构造的foo对象,又foo中没有constructor属性,那么会去它的原型proto中去找,这个proto指向Foo()构造函数。
2、Foo()是一个函数,函数的构造函数是Function

覆盖原型的时候,要重新设置构造函数

如例:

        <script type="text/javascript">
            function Foo(){}
            Foo.prototype.say = function(){
                alert("abc");
            }
            var foo1 = new Foo();
            console.log(foo1.constructor);

            Foo.prototype = {
                say:function(){
                    alert("123");
                }
            }
            var foo2 = new Foo();
            console.log(foo2.constructor);
        </script>

输出结果:
Foo(){}
Object() { [native code] }
输出解析:
为什么第一个是Foo(){} 而第二个是Object()呢?
第一个是Foo()很好解释,因为它是由Foo()构造函数构造的,而第二个是Object的原因是,我们在下面将prototype覆盖了,赋值之后,它不具备了constructor属性,也就是说,foo2.constructor,由于foo2中没有,它就取proto中找,而proto中也没有,它就取proto的proto中去找,而proto的proto是Object的prototype,也就含有constructor属性,值为Object(){}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值