zoukankan      html  css  js  c++  java
  • 什么是构造函数?

    this指向的几种情况

    1.全局中调用

        this.name //this指向window对象
       
    2.函数调用

        test();//test()函数中的this也指向window对象
       
    3.对象的方法调用

        obj1.fn();//obj1对象的fn()方法中的this指向obj1
       
    4.调用构造函数
        var dog=new Dog();//构造函数内的this指向新创建的实例对象,也就是这里的dogcall和apply

    call和apply的作用一样,只是接受参数的方式不一样,call接受的是多个单个参数,apply接受的是参数数组。
    call和apply的作用简单地可以说成,当一个对象实例缺少一个函数/方法时,可以调用其他对象的现成函数/方法,其方式是通过替换其中的this为这个对象实例,改变函数运行时的上下文。

    普通函数与构造函数相比有四个明显特点:

    1.不需要用new关键字调用

        fn();2.可以用return语句返回值

    1
    2
    3
    4
    function fn(a,b){
       return a+b;
     }
     alert(fn(2,3));//alert:5

    3.函数内部不建议使用this关键字
    我们说不建议使用,当然硬要用是可以的,只是要注意这时候发生了什么。如果在普通函数内部使用this关键字定义变量或函数,因为这时候this指向的是window全局对象,这样无意间就会为window添加了一些全局变量或函数。

    1
    2
    3
    4
    5
    6
    function greeting(){
        this.name="sheila";
        alert("hello "+this.name);
      }
      greeting();//alert:hello sheila
      alert(window.name);//alert:sheila

    4.函数命名以驼峰方式,首字母小写

    构造函数
    在JavaScript中,用new关键字来调用定义的构造函数。默认返回的是一个新对象,这个新对象具有构造函数定义的变量和函数/方法。

    举个例子:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    function Prince(name,age){
      this.gender="male";
      this.kind=true;
      this.rich=true;
      this.name=name;
      this.age=age;
    }
    Prince.prototype.toFrog=function(){
      console.log("Prince "+this.name+" turned into a frog.");
    }
    var prince=new Prince("charming",25);
    prince.toFrog();//Prince charming turned into a frog.
    prince.kind;//true

    与普通函数相比,构造函数有以下明显特点:

    1.用new关键字调用

    new关键字来完成:
    a、创建一个空对象;
    b、将关键字this指向这个空对象;
    c、执行构造函数里面的代码,给当前空对象this设置属性和方法;
    d、将this这个当前对象返回。

        var prince=new Prince("charming",25);

    2.函数内部可以使用this关键字
    在构造函数内部,this指向的是构造出的新对象。用this定义的变量或函数/方法,就是实例变量或实例函数/方法。需要用实例才能访问到,不能用类型名访问。

     prince.age;//25
        Prince.age;//undefined

    3.默认不用return返回值
    构造函数是不需要用return显式返回值的,默认会返回this,也就是新的实例对象。当然,也可以用return语句,返回值会根据return值的类型而有所不同,细节将在下文介绍。

    4.函数命名建议首字母大写,与普通函数区分开。
    不是命名规范中的,但是建议这么写。

    1.第一步,创建一个空对象。

    var prince={}

    2.第二步,将构造函数Prince()中的this指向新创建的对象prince。
    3.第三步,将prince的_proto_属性指向Prince函数的prototype,创建对象和原型间关系
    4.第四步,执行构造函数Prince()内的代码。

  • 相关阅读:
    190401装饰器-高阶函数-闭包
    190329迭代器-生成器-三元运算-列表解析
    OpenStack-Mitaka
    RabbitMQ
    190328文件处理
    190322函数
    190322字符串
    190321集合
    190320运算符&数据类型
    Zookeeper
  • 原文地址:https://www.cnblogs.com/Ma-lulu/p/5734869.html
Copyright © 2011-2022 走看看