問答
1.有如下代碼,解釋Person贱除、 prototype外冀、proto寡键、p、constructor之間的關(guān)聯(lián)雪隧。
function Person(name){
this.name = name;
}
Person.prototype.sayName = function(){
console.log('My name is :' + this.name);
}
var p = new Person("若愚")
p.sayName();
- p是構(gòu)造函數(shù)Person 生產(chǎn)的一個(gè)對(duì)象,并且傳遞了參數(shù)為‘若愚’
- p.proto=Person.prototype
- Person.prototype.constructor 指針屬性指向Person函數(shù)本身
- 當(dāng)調(diào)用p.sayName方法時(shí)西轩,先從p1對(duì)象自身找员舵,如果沒找到,就繼續(xù)向上找——Person.prototype,在原型對(duì)象里找到了sayName方法藕畔,此時(shí)this指向調(diào)用它的對(duì)象p1,打印出結(jié)果
'My name is : 若愚'
如果還是沒找到固灵,則會(huì)繼續(xù)向上找,直到Object對(duì)象的原型為止劫流。
2.上例中巫玻,對(duì)對(duì)象 p可以這樣調(diào)用 p.toString()。toString是哪里來的? 畫出原型圖?并解釋什么是原型鏈祠汇。
![]TAZ$YKL32JRC$%~2UBOL.png](http://upload-images.jianshu.io/upload_images/3361706-3704573ebd44f24c.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
- 原型鏈:因?yàn)槊總€(gè)對(duì)象和原型都有原型仍秤,對(duì)象的原型指向原型對(duì)象,而父的原型又指向父的父可很,這種原型層層連接起來的就構(gòu)成了原型鏈诗力。
- 從原型圖上可以清晰的看出,p1.toString方法是在原型鏈上一步一步往上尋找我抠,最終在原型鏈的終端Object.prototype里找到了toString方法
3.對(duì)String做擴(kuò)展苇本,實(shí)現(xiàn)如下方式獲取字符串中頻率最高的字符
var str='ahbbccdeddddfg';
String.prototype.getMostOften=function(){
var obj={};
for(var i=0;i<str.length;i++){
var char=str.charAt(i);
if(obj[char]){
obj[char]++;
console.log(obj[char])
}else{
obj[char]=1;
}
}
console.log(obj);
var max=0;
for(var key in obj){
if(max<obj[key])
max=obj[key]
}
for(var key in obj){
if(obj[key]==max){
console.log('出現(xiàn)最多的字符是'+key)
console.log('出現(xiàn)的次數(shù)'+max)
}
}
}
var ch = str.getMostOften();
console.log(ch); //d , 因?yàn)閐 出現(xiàn)了5次
4.instanceOf有什么作用?內(nèi)部邏輯是如何實(shí)現(xiàn)的菜拓?
-
instanceOf用來判斷一個(gè)對(duì)象是否是另一個(gè)對(duì)象的實(shí)例
function isInstanceOf(obj,Func){ var __proto__=obj.__proto__; do{ if(__proto__===Func.prototype) return true ; if(!__proto__) return false; }while(__proto__=__proto__.__proto__) return false; }