JS_函数篇_构造函数和普通函数的区别

构造函数与普通函数的区别:

*对象和数组 初始化的时候不要用构造函数,要用函数声明式

  1. 构造函数开头是大写,普通函数是小写

  2. 构造函数可以用new 函数名和实例调用,普通函数就是函数名和实例

  3. 构造函数在new的时候就创建了一个实例化对象,而且将this指向指向了这个实例化对象,而普通函数的在函数输入实例化对象执行后,this指向也是实例化以后的对象

  4. 构造函数通过new调用能够返回一个实例化以后的对象

下面是代码,看懂就明白其中的区别了

// 普通函数
   // 如果函数里有this,但是没有被他的上一级对象调用,this指向window,调用了就指向上一级
    function foo(a)
    {
      // 如果没被调用this就指向window,如果没被调用就是打印undefined
      this.c = a;
      // 打印 9
      console.log(this.c);
      return c
    }
    foo(9)
    // 打印 9
    console.log(c);
    // 返回值为9 和 9

// 构造函数
    function Faa(b)
    {
     // 如果没被调用this就指向window,如果没被调用就是打印undefined,从这里可以看出函数内打印可以,函数外不可以。
      this.d = b;
      // 打印 9
      console.log(this.d); 
    }
    let obj = new Faa(1)
    // 打印 {b:1}
    console.log(obj);
    // 报错d is not defined
    console.log(d);
      // 返回值为 1 ,{b:1} 和报错b is not defined
      // 构造函数相当于封装了函数体内的对象,只将实例化对象返回出来
      // 这里用return是不起效果的,因为函数体内有规则
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值