原型链,闭包与继承?

JavaScript,一共有两种类型的值,原始值和对象值。每个对象都有一个内部属性 prototype ,我们通常称之为原型。原型的值可以是一个对象,也可以是null。如果它的值是一个对象,则这个对象也一定有自己的原型。这样就形成了一条线性的链,我们称之为原型链

原型链查找:进行方法调用的时候,会在实例自身上找,如果没有就去该实例的原型上找。

    function People() {

    this.name = 'a People'

    }

    People.prototype.say = function() {

    this.age = '10';

    console.log(this.name, this.age);

    }

    var preson = new People();

    preson.say();

闭包的好处:1.不会污染全局环境;

      2.可以进行形体的记忆,减少形体的个数,延长形参生命周期;   

         function add(x) {

          return function(y) {

            return (x+y);

          }

         }

         var sum = add(2);

         sum(5); //结果等于7

       3.方便进行模块化开发;

         var module = (function() {

          var name = '123';

          function init() {

            console.log(name)

          }

          return {

            getname: init

          }

         })()

         module.getname(); //输出结果:123

继承:一个构造函数继承另一个构造函数的方法,可以省去大量的重复;

    function man(name, age) {

    this.name = name;

    this.age = age;

    }

    var preson = new man('二狗', 18);

    function woman(name, age) {

    this.sex = 'wowowo';

    man.call(this, name, age);

    }

    woman.prototype = man.prototype

    var preson = new woman('二蛋', 20)

    preson1.name; //结果为:二蛋

    preson1.age; //结果为:20

    preson1.sex; //结果为wowowo

posted @ 2018-12-10 10:55  GQMM  阅读(248)  评论(0编辑  收藏  举报