前端面试必备js知识

简介: 前端面试必备js知识

在掘金查看该文章

箭头函数

箭头函数表达式的语法比函数表达式更简洁,并且没有自己的thisargumentssupernew.target。箭头函数表达式更适用于那些本来需要匿名函数的地方,并且它不能用作构造函数。

都说箭头函数不支持 new 运算符。这里实现一个new 运算符来研究下。

function myNew(){
   
   
   const obj = {
   
   }  // 1.创建一个空对象
   const con = [].shift.call(arguments)// 2.获取当前的构造函数
   if(typeof con !== 'function' || typeof con !== 'Function'){
   
   
        throw new TypeError('Type Error')
    }
   obj.__proto__ = con.prototype // 3.链接到构造函数的类型对象
   // 4.将新创建的对象obj作为`this`的上下文
   const res = con.apply(obj,arguments) 
   // 5. 如果有返回对象,原有的会被覆 //盖即下面的判断
  return res instanceof Object ? res : obj 
}

image.png

如我们的实现代码来看,实现中有用到 构造函数,而箭头函数没有构造函数,所以..,另外代码中有用到instanceof运算符用于检测构造函数的 prototype 属性是否出现在某个实例对象的原型链上。也就是我们实现new 运算符中 obj.proto = con.prototype ,那我们来也来实现下。

function myInstanceof(left, right){
   
   
   let prototype = right.prototype
   let proto = left.__proto__

   // ES5的方法,可以获得对象的原型
   // let proto = Object.getPrototypeOf(left);

   while(true){
   
    // 沿着原型链遍历
        if(proto === null || proto === undefined){
   
   
          return false
        }
        if(prototype === proto){
   
   
            return true
        }
        proto = proto.__proto__
    }
}

new.target

new.target 属性允许你检测函数或构造方法是否是通过new运算符被调用的。在通过new运算符被初始化的函数或构造方法中,new.target返回一个指向构造方法或函数的引用。在普通的函数调用中,new.target 的值是undefined

image.png

arguments.callee

描述

calleearguments 对象的一个属性。它可以用于引用该函数的函数体内当前正在执行的函数。这在函数的名称是未知时很有用,例如在没有名称的函数表达式 (也称为“匿名函数”)内

早期版本的 JavaScript不允许使用命名函数表达式,出于这样的原因, 你不能创建一个递归函数表达式;

ECMAScript 3 通过允许命名函数表达式解决这些问题

function foo(){
   
    
  console.log(arguments)
}
undefined
foo()

1.  Arguments [callee: ƒ, Symbol(Symbol.iterator): ƒ]
1.  1.  callee: ƒ foo()
    1.  length: 0
    1.  Symbol(Symbol.iterator): ƒ values()
    1.  [[Prototype]]: Object

image.png

在严格模式下不支持使用arguments.callee,报TypeError错误。

image.png

Function.caller

描述

如果一个函数f是在全局作用域内被调用的,则f.caller为``null,相反,如果一个函数是在另外一个函数作用域内被调用的,则f.caller指向调用它的那个函数.

该属性的常用形式arguments.callee.caller替代了被废弃的 arguments.caller.

Function.caller目前被所有主流浏览器支持: Firefox, Safari, Chrome, Opera 和 IE.

image.png
参考:

https://developer.mozilla.org/zh-CN/docs/web/javascript/reference/functions/arguments/callee

https://juejin.cn/post/7086347680342867976

相关文章
|
12月前
|
JavaScript 前端开发 API
|
前端开发 JavaScript 数据可视化
58K star!这个让网页动起来的JS库,前端工程师直呼真香!
Anime.js 是一款轻量级但功能强大的JavaScript动画引擎,它能够以最简单的方式为网页元素添加令人惊艳的动效。这个项目在GitHub上已经获得58,000+星标,被广泛应用于电商页面、数据可视化、游戏开发等场景。
472 8
|
JavaScript 前端开发 容器
|
资源调度 JavaScript 前端开发
前端开发必备!Node.js 18.x LTS保姆级安装教程(附国内镜像源配置)
本文详细介绍了Node.js的安装与配置流程,涵盖环境准备、版本选择(推荐LTS版v18.x)、安装步骤(路径设置、组件选择)、环境验证(命令测试、镜像加速)及常见问题解决方法。同时推荐开发工具链,如VS Code、Yarn等,并提供常用全局包安装指南,帮助开发者快速搭建高效稳定的JavaScript开发环境。内容基于官方正版软件,确保合规性与安全性。
13264 23
|
JavaScript 前端开发
|
存储 JavaScript 前端开发
|
移动开发 JavaScript 前端开发
|
存储 JavaScript 前端开发
|
JavaScript 前端开发
|
JavaScript 前端开发

热门文章

最新文章

  • 1
    前端如何存储数据:Cookie、LocalStorage 与 SessionStorage 全面解析
    1036
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    441
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    344
  • 4
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    329
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    443
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    619
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    900
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    232
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    732
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    409