首页 > 编程语言 >前端面试题 JavaScript 基础 —— 2022-09-03

前端面试题 JavaScript 基础 —— 2022-09-03

时间:2022-09-03 11:37:35浏览次数:80  
标签:Function 03 面试题 console log ++ 09 prototype true

每日 3 题

13 以下代码执行后,控制台中的输出内容为?

Object.prototype.a = 1;
Function.prototype.b = 2;
function F() {}
var f = new F();
console.log(F.a);
console.log(F.b);
console.log(f.a);
console.log(f.b);

14 以下代码执行后,控制台中的输出内容为?

var a = 2 >= 3 || true && 1 || false;
console.log(a);

15 以下代码执行后,控制台中的输出内容为?

var x = 0;
switch (++x) {
  case 0:
    ++x;
  case 1:
    ++x;
  case 5:
    ++x;
}

console.log(x);

答案及解析

13

// 答案:1 2 1 undefined
// 考察原型链

// 首先对于 Function,这里有几个特殊的点
console.log(typeof Function); // function
console.log(Function.__proto__ === Function.prototype); // true
console.log(Function.prototype.__proto__ === Object.prototype); // true
// 自己动手跑一下记住结果即可

Object.prototype.a = 1; // 在原型对象上添加属性并赋值
Function.prototype.b = 2; // 同上
function F() {}
var f = new F();

// 下面捋一下原型链,"=>" 代表指向
console.log(F.a);
// F.__proto__ => Function.prototype,Function.prototype.__proto__ => Object.prototype
// 顺着原型链找属性 a 即可,找到 Object.prototype.a 为 1

console.log(F.b);
// 原型链同上,找到 Function.prototype.b 为 2

console.log(f.a);
// f.__proto__ => F.prototype
// 注意 F.prototype 只是个普通对象,所以 F.prototype.__proto__ => Object.prototype
// 顺着原型链找属性 a,找到 Object.prototype.a 为 1
console.log(f.b);
// 原型链同上,找不到属性 b,所以结果为 undefined

// 注意 f 和 F 的原型链的区别

14

// 答案:1
// 考察 && 和 || 的优先级以及运算符的理解
// && 的优先级高于 ||
// 故先计算 true && 1
console.log(true && 1); // 问:输出什么

// 答案是 1,回答 true 的对 && 的理解有误
// 对于 expr1 && expr2
// 如果 expr1 能够转化为 true,表达式返回 expr2,否则返回 expr1

// 同理 expr1 || expr2
// 如果 expr1 能够转化为 true,表达式返回 expr1,否则返回 expr2

var a = 2 >= 3 || true && 1 || false;
// 综上,一步一步计算如下
//   (2 >= 3 || true && 1 || false)
// = (2 >= 3 || 1 || false)
// = (1 || false)
// = 1

console.log(a);

15

// 答案:3
// 考察:switch 和 ++
// 首先 ++ 在前会先计算自增 1
// 对于 case 中没有 break 时,匹配到 case 会一直向下计算直到遇到 break
var x = 0;
switch (++x) { // 首先计算括号中式子:结果为 1
  case 0: ++x; // 1 不匹配 0
  case 1: ++x; // 匹配,计算后 x 为 2,并且没有 break,继续向下计算
  case 5: ++x; // 计算 ++x,计算后 x 为 3
}

console.log(x); // 故最终输出 3

标签:Function,03,面试题,console,log,++,09,prototype,true
From: https://www.cnblogs.com/bidong/p/16652214.html

相关文章

  • 信息学一本通 1309:【例1.6】回文数(Noip1999)
    时间限制:1000ms      内存限制:65536KB提交数:17647   通过数:7270【题目描述】若一个数(首位不为零)从左向右读与从右向左读都是一样,我们就将其......
  • 1003:对齐输出
    时间限制:1000ms      内存限制:66536KB提交数:238575   通过数:77457【题目描述】读入三个整数,按每个整数占8个字符的宽度,右对齐输出它们,按照格......
  • luoguP4407 [JSOI2009] 电子字典 解题报告
    传送门题意对于多个字符串,查询其在字典树上的存在性或删除/插入/替换一个字符后存在的个数。思路存在性好说,直接在Trie树上做一遍查找即可。那剩下的三个操作怎么办......
  • 2022-09-02 周五期货走势推演
    玉米主连日线向上通道30分钟中枢震荡5分钟其实突破30分钟上涨趋势,但是注意,日线的上涨趋势还没有突破5分钟以为要下跌,已经有一个箱体的下跌了,结果还是反向上去了。 ......
  • 20220903
    生活不是一帆风顺的。我应该感谢每一个让我成长的机会,感谢每一个烦恼,每一个挫折。他们让我的生活变得丰富,而非平淡枯燥。或许,等多年后的我想起过去自己所经历过的的迷茫......
  • 2022-09-02 周末eurusd总结
    本周持续震荡,4h的k线图一直重叠(这种行情应该过滤不做,你不做,不亏钱,就是赚钱了),30分钟笔中枢,难有大趋势周四的时候终于跌破了这个上升通道,考虑做空,白色箭头为跌破时候最好的......
  • 解决:'webpack-dev-server' 不是内部或外部命令,也不是可运行的程序 或批处理文件 根目
    解决:'webpack-dev-server'不是内部或外部命令,也不是可运行的程序或批处理文件根目录删除node_modules文件夹运行“npmrundev”相信很多人在使用webpack-dev-server......
  • NC51189 Mondriaan's Dream
    题目链接题目题目描述SquaresandrectanglesfascinatedthefamousDutchpainterPietMondriaan.Onenight,afterproducingthedrawingsinhis'toiletseries......
  • redis面试题
    Rdeis面试42问(qq.com)1.简单介绍一下Redis呗!2.分布式缓存常见的技术选型方案有哪些?3.说一下Redis和Memcached的区别和共同点4.缓存数据的处理流程是怎样的?5.......
  • Uncaught TypeError: Cannot read property 'type' of undefined
    今天学习vue3中的ref,运行代码就报这种错误,网上各种方法试了不行,后面发现是返回对象中没返回定义的名字,但是报错是不会直接报名字没定义,我写的对象类型ref,其中定义了个type,......