新问题集!由于最后一个问题列表很受欢迎,因此下面是一个新列表来挑战您!
以下问题旨在具有挑战性和指导意义。如果您确切地知道如何回答每个问题,那很好,但是如果您遇到了一些错误并了解了为什么会出错,那么我认为那会更好!
如果您从测验中学到任何东西,请在评论中让我知道!
以下代码段是否说明了立即调用函数表达式(IIFE),高阶函数(HOF),或者两者都不显示?
((fn, val) => { return fn(val);})(console.log, 5);
答: IIFE和HOF
该片段清楚地说明了通过使IIFE,我们立即调用的函数console.log,并5给它。此外,我们发现这就像fn函数一样是HOF ,并且HOF定义为将另一个函数作为参数或返回函数的任何函数。
二者a并b具有相同属性和值的对象。哪个更有效地创建?
const arr = [1, 2, 3];const a = arr.reduce( (acc, el, i) => ({ ...acc, [el]: i }), {});const b = {};for (let i = 0; i < arr.length; i++) { b[arr[i]] = i;}
答案: b
当b被设置时,b[arr[i]]属性被设置为在每次迭代的当前索引。设置a时,扩展语法(...)将acc在每次迭代时创建累加器对象()的浅表副本,并另外设置新属性。与不执行浅表复制相比,此浅表复制更加昂贵。a需要在达到结果之前构造2个中间对象,b而不构造任何中间对象。因此,b被更有效地设置。
考虑一下superheroMaker功能。当我们传递以下两个输入时,记录了什么?
const superheroMaker = a => { return a instanceof Function ? a() : a;};console.log(superheroMaker(() => 'Batman'));console.log(superheroMaker('Superman'));
答:"Batman" "Superman"
传递() => 'Batman'给时superheroMaker,a是的实例Function。因此,将调用该函数,并返回string "Batman"。当传递"Superman"给superheroMaker时,a它不是的实例,Function因此"Superman"仅返回字符串。因此,输出为"Batman"和"Superman"。
考虑以下对象。
const obj = { 1: 1, 2: 2, 3: 3};
是Object.keys等于Object.values?
console.log(Object.keys(obj) == Object.values(obj));
答:错误
在这种情况下,Object.keys将键转换为字符串["1", "2", "3"]并Object.values给出[1, 2, 3]。即使值的类型相同,两个数组在内存中都是不同的对象,所以相等比较将返回false。您将在这里看到很多测验问题,深入探讨对象和数组比较的概念!
考虑以下递归函数。如果将字符串传递"Hello World"给它,将记录什么?
const myFunc = str => { if (str.length > 1) { return myFunc(str.slice(1)); } return str;};console.log(myFunc('Hello world'));
回答: "d"
第一次调用该函数时,str.length它大于1(等于"Hello World"11个字符),因此我们返回调用的相同函数str.slice(1),即string "ello World"。我们重复此过程,直到字符串只有一个字符长:该字符"d",该字符将返回到的初始调用myFunc。然后,我们记录该字符。
当我们测试以下相等方案时,记录了什么?
const a = c => c;const b = c => c;console.log(a == b);console.log(a(7) === b(7));
答:false true
在第一个测试中,a和b是内存中的不同对象;每个函数定义中的参数和返回值都相同并不重要。因此,a不等于b。在第二个测试中,a(7)返回数字7并b(7)返回number 7。这些基本类型彼此严格相等。
在这种情况下,相等(==)与身份(===)比较运算符无关紧要;任何类型的强制都不会影响结果。
a并且b具有相同的不同对象firstName属性。这些属性是否彼此严格相等?
const a = { firstName: 'Bill'};const b = { firstName: 'Bill'};console.log(a.firstName === b.firstName);
答:true
答案是肯定的。a.firstName是字符串值"Bill",b.firstName是字符串值"Bill"。两个相同的字符串始终相等。
假设myFunc是一个函数,val1是一个变量,并且val2是一个变量。JavaScript是否允许以下语法?
myFunc(val1)(val2);
答:yes
这是高阶函数的常见模式。如果myFunc(val1)返回一个函数,则该函数将val2作为参数被调用。这是一个实际的示例,您可以尝试一下:
const timesTable = num1 => { return num2 => { return num1 * num2; };};console.log(timesTable(4)(5));// 20
考虑对象a及其b下方。记录了什么?
const a = { firstName: 'Joe' };const b = a;b.firstName = 'Pete';console.log(a);
回答: { firstName: 'Pete' }
当我们b = a在第二行中设置时,b并a指向内存中的同一对象。因此firstName,b将属性更改为on 将更改firstName内存中唯一对象的属性,因此a.firstName将反映此更改。
以下函数将始终返回数组中的最大数字吗?
function greatestNumberInArray(arr) { let greatest = 0; for (let i = 0; i < arr.length; i++) { if (greatest < arr[i]) { greatest = arr[i]; } } return greatest;}
答:no
对于至少一个值0大于或等于一个的数组,此函数将正常工作。但是,如果所有数字均低于,它将失败0。这是因为,0即使0大于所有数组元素,最大变量也会从处开始。
《JavaScript图表库的5个首选》
《一文彻底搞懂JavaScript 中Object.freeze与Object.seal的用法》
《可视化的 JS:动态图演示 - 事件循环 Event Loop的过程》
《教你如何用动态规划和贪心算法实现前端瀑布流布局「实践」》
《可视化的 js:动态图演示 Promises & Async/Await 的过程》
《原生JS封装拖动验证滑块你会吗?「实践」》
《如何实现高性能的在线 PDF 预览》
《细说使用字体库加密数据-仿58同城》
《Node.js要完了吗?》
《Pug 3.0.0正式发布,不再支持 Node.js 6/8》
《纯JS手写轮播图(代码逻辑清晰,通俗易懂)》
《JavaScript 20 年 中文版之创立标准》
《值得收藏的前端常用60余种工具方法「JS篇」》
《箭头函数和常规函数之间的 5 个区别》
《通过发布/订阅的设计模式搞懂 Node.js 核心模块 Events》
《「前端篇」不再为正则烦恼》
《「速围」Node.js V14.3.0 发布支持顶级 Await 和 REPL 增强功能》
《深入细品浏览器原理「流程图」》
《JavaScript 已进入第三个时代,未来将何去何从?》
《前端上传前预览文件 image、text、json、video、audio「实践」》
《深入细品 EventLoop 和浏览器渲染、帧动画、空闲回调的关系》
《推荐13个有用的JavaScript数组技巧「值得收藏」》
《前端必备基础知识:window.location 详解》
《不要再依赖CommonJS了》
《犀牛书作者:最该忘记的JavaScript特性》
《36个工作中常用的JavaScript函数片段「值得收藏」》
《Node + H5 实现大文件分片上传、断点续传》
《一文了解文件上传全过程(1.8w字深度解析)「前端进阶必备」》
《【实践总结】关于小程序挣脱枷锁实现批量上传》
《手把手教你前端的各种文件上传攻略和大文件断点续传》
《字节跳动面试官:请你实现一个大文件上传和断点续传》
《谈谈前端关于文件上传下载那些事【实践】》
《手把手教你如何编写一个前端图片压缩、方向纠正、预览、上传插件》
《最全的 JavaScript 模块化方案和工具》
《「前端进阶」JS中的内存管理》
《JavaScript正则深入以及10个非常有意思的正则实战》
《前端面试者经常忽视的一道JavaScript 面试题》
《一行JS代码实现一个简单的模板字符串替换「实践」》
《JS代码是如何被压缩的「前端高级进阶」》
《前端开发规范:命名规范、html规范、css规范、js规范》
《【规范篇】前端团队代码规范最佳实践》
《100个原生JavaScript代码片段知识点详细汇总【实践】》
《关于前端174道 JavaScript知识点汇总(一)》
《关于前端174道 JavaScript知识点汇总(二)》
《关于前端174道 JavaScript知识点汇总(三)》
《几个非常有意思的javascript知识点总结【实践】》
《都2020年了,你还不会JavaScript 装饰器?》
《JavaScript实现图片合成下载》
《70个JavaScript知识点详细总结(上)【实践】》
《70个JavaScript知识点详细总结(下)【实践】》
《开源了一个 JavaScript 版敏感词过滤库》
《送你 43 道 JavaScript 面试题》
《3个很棒的小众JavaScript库,你值得拥有》
《手把手教你深入巩固JavaScript知识体系【思维导图】》
《推荐7个很棒的JavaScript产品步骤引导库》
《Echa哥教你彻底弄懂 JavaScript 执行机制》
《一个合格的中级前端工程师需要掌握的 28 个 JavaScript 技巧》
《深入解析高频项目中运用到的知识点汇总【JS篇】》
《JavaScript 工具函数大全【新】》
《从JavaScript中看设计模式(总结)》
《身份证号码的正则表达式及验证详解(JavaScript,Regex)》
《浏览器中实现JavaScript计时器的4种创新方式》
《Three.js 动效方案》
《手把手教你常用的59个JS类方法》
《127个常用的JS代码片段,每段代码花30秒就能看懂-【上】》
《深入浅出讲解 js 深拷贝 vs 浅拷贝》
《手把手教你JS开发H5游戏【消灭星星】》
《深入浅出讲解JS中this/apply/call/bind巧妙用法【实践】》
《手把手教你全方位解读JS中this真正含义【实践】》
《书到用时方恨少,一大波JS开发工具函数来了》
《干货满满!如何优雅简洁地实现时钟翻牌器(支持JS/Vue/React)》
《手把手教你JS 异步编程六种方案【实践】》
《让你减少加班的15条高效JS技巧知识点汇总【实践】》
《手把手教你JS开发H5游戏【黄金矿工】》
《手把手教你JS实现监控浏览器上下左右滚动》
《JS 经典实例知识点整理汇总【实践】》
《2.6万字JS干货分享,带你领略前端魅力【基础篇】》
《2.6万字JS干货分享,带你领略前端魅力【实践篇】》
《简单几步让你的 JS 写得更漂亮》
《恭喜你获得治疗JS this的详细药方》
《谈谈前端关于文件上传下载那些事【实践】》
《面试中教你绕过关于 JavaScript 作用域的 5 个坑》
《Jquery插件(常用的插件库)》
《【JS】如何防止重复发送ajax请求》
《JavaScript+Canvas实现自定义画板》
《Continuation 在 JS 中的应用「前端篇」》