美文网首页
原型、原型链、原型继承

原型、原型链、原型继承

作者: Komolei | 来源:发表于2017-05-05 22:26 被阅读0次

this 相关问题
问题1: apply、call 、bind有什么作用,什么区别

作用: 给函数指定this。是用来指定上下文的
区别: bind:bind()会创建一个新的函数,将其中的值,作为原来函数的this。例如xx.bind(obj)中,obj为xx的this 。将函数体中的this绑定到对象上,然后返回一个新的函数。
call: call()是使用一个指定的this值和相关参数的前提下调用函数或方法。接受的参数为若干个参数的列表。简单来说,就是可以指定函数内部this的指向(即在此函数执行时所在的作用域),让在所指定的作用域中,调用该函数。就是var obj={};function fn(){ return this;};fn.call(obj),call改变this的指向。让fn的this是指向obj的,在obj的作用域中运行
apply: apply()效果同call(),不过其接受的参数为数组。

问题2: 以下代码输出什么?

 var john = { 
        firstName: "John" 
          }
    function func() { 
        alert(this.firstName + ": hi!")
    }
    john.sayHi = func
    john.sayHi()  ==》方法调用
    输出:  
              john hi!

问题3: 下面代码输出什么,为什么

func() 
function func() { 
  alert(this)
}        ==》函数调用
输出: window,因为在function中的this,没有找到对象,所以继续向外找,
            而function的外部环境为window,则输出window

问题4:下面代码输出什么

document.addEventListener('click', function(e){
   console.log(this);
   setTimeout(function(){
   console.log(this);
    }, 200);
}, false);

输出:document 
           window

问题5:下面代码输出什么,why

var john = { 
  firstName: "John" 
}
function func() { 
  alert( this.firstName )
}
func.call(john)

输出:john

原因:call()函数为func函数绑定了this=john

call()函数将func函数的this指向了john,并且func的执行在john的作用域中

问题6: 以下代码有什么问题,如何修改

var module= {
    bind: function(){
      $btn.on('click', function(){
        console.log(this) //this指什么
    this.showMsg();
  })
},  
    showMsg: function(){
      console.log('饥人谷');
  }
}

问题:console.log出来的是$btn 饥人谷 ;//不知道。
当调用module.bind()的时候。this.showMsg()无法调用。因为这里的this指向了$btn。所以将this.showMsg()改为module.showMsg();
或是通过嫁接方式;var that=this;that.showMsg();
原型链相关问题

问题7:有如下代码,解释Person、 prototype、proto、p、constructor之间的关联。

function Person(name){
    this.name = name;
}
Person.prototype.sayName = function(){
    console.log('My name is :' + this.name);
}
var p = new Person("若愚")
p.sayName();
关联:p是Person的构造对象,而Person是构造函数。 在new的过程中,p的-proto-指向 Person,因为Person的原型上绑定一个方法:sayName,即constructor下有sayName。所以p 拥有属性:name;和方法sayName()。

问题8: 上例中,对对象 p可以这样调用 p.toString()。toString是哪里来的? 画出原型图?并解释什么是原型链。
来自上一级的原型。
https://www.draw.io/#Hkomolei%2Ftry%2Fmaster%2FUntitled%20Diagram.xml
原型链:所有的对象都有-proto-这个属性,这个链接到另一个-proto-,像这样一个个-proto-相链接起来的样子,称为原型链。对于函数,则是prototype了。
问题9:对String做扩展,实现如下方式获取字符串中频率最高的字符

 var str = 'ahbbccdeddddfg';
 String.prototype.getMostOften =
  function () {
   // var str = 'ahbbccdeddddfg';
   var str=this;
    // console.log(this);
   var o = {};
   for (var i = 0; i < str.length; i++) {
   var char = str.charAt(i);
   if (o[char]) {
      o[char]++; //次数加1
    } else {
      o[char] = 1; //若第一次出现,次数记为1
    }
  }
  // console.log(o); //输出的是完整的对象,记录着每一个字符及其出现的次数
  //遍历对象,找到出现次数最多的字符的次数
  var max = 0;
  for (var key in o) {
    if (max < o[key]) {
      max = o[key]; //max始终储存次数最大的那个
    }
  }
  for (var key in o) {
    if (o[key] == max) {
      //console.log(key);
      // console.log("最多的字符是" + key);
      // console.log("出现的次数是" + max);
      return key;
    }
  }
}
var ch = str.getMostOften();
 console.log(ch);

问题10: instanceOf有什么作用?内部逻辑是如何实现的?

作用: instanceof 运算符用来测试一个对象在其原型链中是否存在一个构造函数的 prototype 属性。
就是检测一个原型链上是否存在某个prototype。a.instanceof b.prototype :就是a的原型链中是否存在b.prototype;
实现逻辑:让其一层一层沿着原型链去查找,找到就return true;
继承相关问题

问题11:继承有什么作用?
继承:一个对象继承另一个对象的所有的属性和方法。可以得到另一个对象的属性和方法。

问题12: 下面两种写法有什么区别?

//方法1
function People(name, sex){
    this.name = name;
    this.sex = sex;
    this.printName = function(){
      console.log(this.name);
    }
}
var p1 = new People('饥人谷', 2)

//方法2
function Person(name, sex){
    this.name = name;
    this.sex = sex;
}

Person.prototype.printName = function(){
    console.log(this.name);
}
var p1 = new Person('若愚', 27);

区别:方法1是 绑定在People上。方法2的printName是绑定到原型上。在new多个实例的时候,方法2可以直接调用。在多次调用的时候可以优化内存空间。而方法1要多次写入。
同时方法2中要更改prototype的时候,其的每一个实例的printName都会改变。而方法1需要每个都是修改。

问题13: Object.create 有什么作用?兼容性如何?

Object.create() 方法使用指定的原型对象和其属性创建了一个新的对象。简单来说就是可以手动的去指定对象的原型。创建一个新的对象,第一层的原型链指向对应的参数。
兼容性:支持各个浏览器。ie需要ie9以上。

问题14: hasOwnProperty有什么作用? 如何使用?

作用:看对象上的属性是属于自己的,还是从原型链继承来的。
使用:object.hasOwnPrototype(" 属性")

问题15:如下代码中call的作用是什么?

function Person(name, sex){
    this.name = name;
    this.sex = sex;
}
function Male(name, sex, age){
    Person.call(this, name, sex);    //这里的 call 有什么作用
    this.age = age;
}

作用:让Male继承Person中的属性。手动将this指向Person。就是将Person中的this引用到Male中。

问题16: 补全代码,实现继承

function Person(name, sex){
    // todo ...
    this.name=name;
    this.sex=sex;
}

Person.prototype.getName = function(){
    // todo ...
    console.log(this.name);
};    

function Male(name, sex, age){
   //todo ...
    Person.call(this,name,sex)
    this.age=age;
    //this.printName=function(){
      //    console.log(this.name)
      //}
      this.printName=Person.prototype.getName;
  }

  //todo ...
Male.prototype.getAge = function(){
  //todo ...
   console.log(this.age)
};

var ruoyu = new Male('若愚', '男', 27);
ruoyu.printName();

或是:

function Person(name, sex){        
    this.name=name;
    this.sex=sex;
}

Person.prototype.printName = function(){       
    console.log(this.name);
};    

function Male(name, sex, age){
  
    Person.call(this,name,sex)
    this.age=age;
    //this.printName=function(){
      //    console.log(this.name)
      //}
      //this.printName=Person.prototype.getName;
  }
  //todo ...  
Male.prototype=new Person() ; //继承:将一个对象的prototype指向要继承的对象即可
Male.prototype.getAge = function(){
//       todo ...
  console.log(this.age)
};
var ruoyu = new Male('若愚', '男', 27);
ruoyu.printName();

相关文章

  • JavaScript 原型、原型链与原型继承

    原型,原型链与原型继承 用自己的方式理解原型,原型链和原型继承 javascript——原型与原型链 JavaSc...

  • 继承

    原型链直接继承 原型链直接继承prototype 原型链继承_prototype属性 继承_构造函数绑定

  • js中的实现继承的几种方式

    大纲:原型链借用构造函数组合继承原型式继承寄生式继承寄生组合式继承 1、原型链: 什么是原型链? 原型链的基本思想...

  • Javascript 面向对象的程序设计(原型链与继承)

    继承 原型链 讲原型的时候提到过继承,设计原型的初衷就是为了继承,原型链是实现继承的主要方法。那什么是原型链,还记...

  • js基础之实现继承的几种方式

    js 实现继承的方式有: 原型链继承; 构造函数继承; 组合继承(原型链继承 + 构造函数继承)(最常用);(原型...

  • es5的部分继承以及es6的class

    一、JavaScript常用的原型继承方式 原型链继承 2,构造函数继承(对象冒充继承) 3,组合继承(原型链继承...

  • js原型、原型链、继承的理解

    一、原型、原型链 原型是Javascript中的继承的基础,JavaScript的继承主要依靠原型链来实现的。 原...

  • 构造函数原型的继承方式分析

    1.通过原型链继承 综上我们可以总结出 通过原型链来实现继承的原理通过原型链来实现继承的原理原型链继承方案中,父类...

  • js_继承及原型链等(四)

    js_继承及原型链等(三) 1. 继承 依赖于原型链来完成的继承 发生在对象与对象之间 原型链,如下: ==原型链...

  • js 继承

    4种继承方式 原型式继承给原型对象添加属性原型替换子类的原型对象替换为父类的原型对象 原型链继承 借用构造函数继承...

网友评论

      本文标题:原型、原型链、原型继承

      本文链接:https://www.haomeiwen.com/subject/ijnstxtx.html