前端面试(题三)js

时间:2022-07-22
本文章向大家介绍前端面试(题三)js,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

1.call、apply及bind的区别

2.自己实现instanceof (考点:原型链;递归)

 3.自己实现new (考点:JS对象的实现化;原型链)

 5.判断一个数据的类型

①. toString.call()

 ②. typeof

 6. js深拷贝

function deepCopy (source) {
    var target = Array.isArray(source) ? [] : {};
    for (let key in source) {
        if (source.hasOwnProperty(key)) {
            if (typeof source[key] === 'object') {
                target[key] = deepCopy(source[key]);
            } else {
                target[key] = source[key];
            }
        }
    }
    return target;
}

7,输出结果

function test(n, o) {
    console.log(o);
    return {
        test: function (m) {
            return test(m, n);
        }
    };
}
 
var a = test(0);
a.test(1);
a.test(2);
var b = test(0).test(1).test(2).test(3);
var c = test(0).test(1);
c.test(2);
c.test(3);

输出参考:

undefined 0 0 undefined 0 1 2 undefined 0 1 1

8.async/await的了解

async函数返回的是一个promise对象,如果async函数中有return语句,那么promise对象resolve拿到的数据就是这个return后的数据。如果没有,那么就是undefined。async函数的内部是同步的方式执行的。

9.构造函数的理解

function Person(name){
    this.name = name;
    return name;
}
let p1 = new Person('Tom');
function Person(name){
    this.name = name;
    return {};
}
let p2 = new Person('Tom');

p1为{name:‘Tom’},而p2为{}。

解释:构造函数不需要显示的返回值。使用new来创建对象(调用构造函数)时,如果return的是非对象(数字、字符串、布尔类型等)会忽略返回值,返回的是this;如果return的是对象,则返回该对象(注:若return null也会忽略返回值)。

10.函数的防抖与节流的简单代码实现