一道面试题就能测出你的JavaScript水平

发布时间:2024-11-29 23:28

JavaScript实战书籍:《你不知道的JavaScript》深入解析 #生活技巧# #工作学习技巧# #编程学习资源#

IT-博通哥 于 2020-12-09 22:30:30 发布

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

function Parent() {

this.a = 1;

this.b = [1, 2, this.a];

this.c = { demo: 5 };

this.show = function () {

console.log(this.a , this.b , this.c.demo );

}

}

function Child() {

this.a = 2;

this.change = function () {

this.b.push(this.a);

this.a = this.b.length;

this.c.demo = this.a++;

}

}

Child.prototype = new Parent();

var parent = new Parent();

var child1 = new Child();

var child2 = new Child();

child1.a = 11;

child2.a = 12;

parent.show();

child1.show();

child2.show();

child1.change();

child2.change();

parent.show();

child1.show();

child2.show();

这是一道非常好的面试题, 考察以下知识点:

this的指向

原型(prototype)以及原型链

继承

引用

要解出这道题,要理解以下几句话就可以了:

每一个构造函数,都有一个原型[[prototype]]属性 指向构造函数的原型对象

每一个实例生成的时候,都会在内存中产生一块新的堆内存

每一实例都有一个隐式原型__proto__ 指向构造函数的原型对象

this的指向 取决于this调用时的位置, 在这道题中, 也可以简单理解为, 谁调用方法, this就指向哪个对象

数组和字面量对象 都是 引用

原型链的查找规则: 就近原则

当实例上存在属性时, 用实例上的

如果实例不存在,顺在原型链,往上查找,如果存在,就使用原型链的

如果原型链都不存在,就用Object原型对象上的

如果Object原型对象都不存在, 就是undefined

为了帮助大家, 我贴出课堂上的示意图, 如果有不理解的,欢迎互动,交流

图片

图片

最后,想学习前端的小伙伴们!

博主自己建的微信公众号:web前端技术圈 (回复2020,可以下载一些编程开发工具和项目实战)

如果还在IT编程的世界里迷茫,不知道自己的未来规划,学习没有动力,东也学一下,西也学习一下,那你可以加入web前端学习交流Q群:733581373, 里面有大神一起交流并走出迷茫。新手可进群免费领取学习资料,分享一些学习的方法和需要注意的小细节,每晚八点也会准时的讲一些前端的小案例项目。

​​在这里插入图片描述

网址:一道面试题就能测出你的JavaScript水平 https://www.yuejiaxmz.com/news/view/317460

相关内容

心理压力测试20题:全面评估你的压力水平
趣味逆商大挑战,10道逆商测试题,测出你的抗压能力
压力水平测试
自动化测试面试题库
测试人员的价值=自动化测试的水平?
17道题测试你的压力有多大
hr面试性格测试30题
面试
压力水平测试,寻找平衡的生活方式
JavaScript常用优化分享(三)

随便看看