前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >前端面试(题三)js

前端面试(题三)js

作者头像
用户3055976
发布2020-08-05 22:20:32
3680
发布2020-08-05 22:20:32
举报
文章被收录于专栏:知道一点点

1.call、apply及bind的区别

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

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

 5.判断一个数据的类型

①. toString.call()

 ②. typeof

 6. js深拷贝

代码语言:javascript
复制
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,输出结果

代码语言:javascript
复制
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.构造函数的理解

代码语言:javascript
复制
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.函数的防抖与节流的简单代码实现

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-08-03 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档