問答
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)的一個對象,并且傳遞了參數(shù)為‘若愚’
- p.proto=Person.prototype
- Person.prototype.constructor 指針屬性指向Person函數(shù)本身
- 當(dāng)調(diào)用p.sayName方法時,先從p1對象自身找,如果沒找到,就繼續(xù)向上找——Person.prototype,在原型對象里找到了sayName方法,此時this指向調(diào)用它的對象p1,打印出結(jié)果
'My name is : 若愚'如果還是沒找到,則會繼續(xù)向上找,直到Object對象的原型為止。
2.上例中,對對象 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)
- 原型鏈:因為每個對象和原型都有原型,對象的原型指向原型對象,而父的原型又指向父的父,這種原型層層連接起來的就構(gòu)成了原型鏈。
- 從原型圖上可以清晰的看出,p1.toString方法是在原型鏈上一步一步往上尋找,最終在原型鏈的終端Object.prototype里找到了toString方法
3.對String做擴(kuò)展,實現(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 , 因為d 出現(xiàn)了5次
4.instanceOf有什么作用?內(nèi)部邏輯是如何實現(xiàn)的?
-
instanceOf用來判斷一個對象是否是另一個對象的實例
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; }