88期
1. 说一下你对虚拟dom的理解
2. 懒加载和预加载是如何提升用户体验的
3. 单页面应用中,通常会出现长时间的白屏,如何解决?
上面问题的答案会在第二天的公众号(程序员每日三问)推文中公布
87期问题及答案
1. js中数据中检测数据类型的方法有哪些?
在 JavaScript 中,有多种方法来检测数据的类型。以下是一些常见的方式:
typeof 操作符:
typeof
操作符用于检测变量或值的基本数据类型,返回一个表示数据类型的字符串。它适用于大多数数据类型,但不适用于检测复杂的对象类型。typeof 42; // "number" typeof "Hello"; // "string" typeof true; // "boolean" typeof undefined; // "undefined" typeof null; // "object" (这是一个 typeof 的历史遗留问题) typeof {}; // "object" typeof []; // "object" typeof function() {}; // "function"
instanceof 操作符:
instanceof
操作符用于检测对象是否是某个构造函数的实例。它通常用于检测自定义构造函数创建的对象。const today = new Date(); today instanceof Date; // true
Object.prototype.toString 方法:
Object.prototype.toString
方法可以返回一个表示对象的具体内部类型的字符串。Object.prototype.toString.call(42); // "[object Number]" Object.prototype.toString.call("Hello"); // "[object String]" Object.prototype.toString.call(true); // "[object Boolean]" Object.prototype.toString.call(undefined); // "[object Undefined]" Object.prototype.toString.call(null); // "[object Null]" Object.prototype.toString.call({}); // "[object Object]" Object.prototype.toString.call([]); // "[object Array]" Object.prototype.toString.call(function() {}); // "[object Function]"
Array.isArray 方法:
Array.isArray
方法用于检测一个值是否是数组类型。Array.isArray([]); // true Array.isArray({}); // false
typeof null 的陷阱:
注意,
typeof null
返回的是 "object",这是 JavaScript 的一个历史遗留问题,不应该用来检测null
。NaN 和 Infinity 的检测:
isNaN
和isFinite
函数用于检测特殊的数值类型。isNaN(NaN); // true isFinite(42); // true
正则表达式:
正则表达式可以用于检测字符串是否符合特定的模式,用于验证字符串类型。
const regex = /^[0-9]+$/; regex.test("123"); // true regex.test("abc"); // false
选择合适的检测方法取决于你的需求。通常,typeof
用于基本类型,instanceof
用于检测对象类型,Array.isArray
用于检测数组,Object.prototype.toString
用于更精确地检测内部类型。
2. 如何用reduce函数实现数组去重?
你可以使用 reduce
方法来实现数组去重。 reduce
可以帮助你迭代数组,并根据指定的条件构建一个新数组,去除重复的元素。以下是一个使用 reduce
实现数组去重的示例:
const array = [1, 2, 2, 3, 4, 4, 5];
const uniqueArray = array.reduce((accumulator, currentValue) => {
if (!accumulator.includes(currentValue)) {
accumulator.push(currentValue);
}
return accumulator;
}, []);
console.log(uniqueArray); // [1, 2, 3, 4, 5]
在这个示例中,reduce
方法初始化一个空数组 []
作为初始值,并依次迭代原始数组中的元素。对于每个元素,如果它在累加器数组中不存在(使用 includes
方法检查),则将其添加到累加器中。最后,返回累加器,得到去重后的数组。
这种方法简单且有效,但需要注意,它的时间复杂度为 O(n^2),因为在每次迭代中都使用了 includes
方法来检查元素是否存在。对于大型数组,可能不够高效。如果性能是一个关键问题,可以考虑其他更高效的去重方法,如使用 Set 数据结构:
const array = [1, 2, 2, 3, 4, 4, 5];
const uniqueArray = [...new Set(array)];
console.log(uniqueArray); // [1, 2, 3, 4, 5]
使用 Set 还能更简洁地实现数组去重,而且具有更好的性能,因为 Set 内部的元素是唯一的。
3. 箭头函数和普通函数的区别?
箭头函数和普通函数(也称为函数表达式或函数声明)在 JavaScript 中有一些重要的区别:
语法形式:
箭头函数:箭头函数使用
=>
语法来定义,它可以是一个匿名函数,也可以是具名函数。const add = (a, b) => a + b;
普通函数:普通函数可以使用函数声明或函数表达式的形式来定义。
// 函数声明 function add(a, b) { return a + b; } // 函数表达式 const add = function(a, b) { return a + b; };
this 的绑定:
箭头函数:箭头函数没有自己的
this
绑定,它会捕获其所在上下文的this
值。这意味着箭头函数内部的this
始终指向定义它的外部函数或作用域的this
。普通函数:普通函数的
this
值取决于如何调用它。在全局作用域中,this
可能指向window
对象。在函数内部,this
的值可以通过函数的调用方式来确定。
arguments 对象:
箭头函数:箭头函数没有自己的
arguments
对象。如果需要访问参数,可以使用 rest 参数语法。普通函数:普通函数内部有
arguments
对象,可以访问传递给函数的所有参数。
构造函数:
箭头函数:箭头函数不能用作构造函数,不能使用
new
关键字调用它们来创建对象实例。普通函数:普通函数可以作为构造函数,可以使用
new
关键字创建对象实例。
返回值的默认行为:
箭头函数:如果箭头函数只包含一条表达式,它将自动返回该表达式的值,无需显式使用
return
。普通函数:普通函数需要显式使用
return
语句来返回值。
适用场景:
箭头函数:通常用于无需自己的
this
上下文、短小的函数,或需要保留外部上下文的回调函数。普通函数:用于大多数函数场景,尤其是需要自己的
this
上下文或作为构造函数使用时。
总之,箭头函数和普通函数有不同的用途和行为。选择使用哪种函数取决于你的需求,特别是在处理 this
和函数的作用域时要格外注意。
如果觉得这篇文章对你有帮助,希望多多点赞收藏加关注,也希望分享给更多爱学习的小伙伴,你的肯定是我最大的动力。
学习不打烊,充电加油只为遇到更好的自己,每天早上9点纯手工发布面试题(死磕自己,愉悦大家) 希望大家在这浮夸的程序员圈里保持冷静,每天坚持花20分钟来学习与思考,在千变万化,类库层出不穷的今天,不要等到找工作时才狂刷题,提倡每日学习。