14가지 어려운 JavaScript 인터뷰 질문에 대한 코드 예제의 자세한 분석
프론트엔드 엔지니어는 면접 중에 일종의 면접관을 만날 때가 있습니다. 그들이 묻는 질문은 언어 자체에 대해 매우 현실적이며 후보자가 기대할 수 있는 실용적인 질문이 아닌 경우가 많습니다(일부 후보자는 오랫동안 강조함). 일을 할 수 있기 때문에 이유를 알든 모르든 상관없습니다.) 이러한 유형의 질문은 비논리적이지만 어느 정도는 javascript
언어에 대한 응시자의 이해도를 테스트합니다.
심심해서 Github을 뒤지며 이전에 어떤 추악한 내용을 썼는지 살펴보던 중 갑자기 이 주제가 생각났습니다. 그러다가 자바스크립트 퀴즈를 설명하는 퀴즈-전설 기사를 발견했습니다. 어쨌든 괜찮으니 모두가 배우고, 이해하고, 암송하고, 비판할 수 있도록 여기에 옮겨두고자 합니다.
질문 1
(function(){ return typeof arguments;//"object" })();
arguments
는 함수에 전달된 매개변수 목록에 해당하는 배열과 유사한 객체입니다. 이 변수는 모든 함수에서 직접 사용할 수 있습니다.
typeof
연산자는 string
유형의 결과만 반환합니다. 다양한 데이터에 대해 typeof
에서 반환된 값이 무엇인지 확인하려면 다음 목록을 참조하세요.
类型 | 结果 |
---|---|
undefined | 'undefined' |
null | 'object' |
Boolean | 'boolean' |
Number | 'number' |
String | 'string' |
Symbol (new in ECMAScript 2015) | 'symbol' |
Host object (provided by the JS environment) | Implementation-dependent |
Function object (implements [[Call]] in ECMA-262 terms) | 'function' |
Any other object | 'object' |
由此我们推断出,
typeof arguments
是object
问题二
var f = function g(){ return 23; }; typeof g();//报错
这是一个名字是g
的function expression,然后又被赋值给了变量f
。
这里的函数名g
和被其赋值的变量f
有如下差异:
函数名
g
不能变动,而变量f
可以被重新赋值函数名
g
只能在函数体内部被使用,试图在函数外部使用g
会报错的
问题三
(function(x){ delete x; return x;//1 })(1);
delete
操作符可以从对象中删除属性,正确用法如下:
delete object.property delete object['property']
delete
操作符只能作用在对象的属性上,对变量和函数名无效。也就是说delete x
是没有意义的。
你最好也知道,
delete
是不会直接释放内存的,她只是间接的中断对象引用
问题四
var y = 1, x = y = typeof x; x;//"undefined"
我们试图分解上述代码成下面两步:
var y = 1; //step 1 var x = y = typeof x; //step 2
第一步应该没有异议,我们直接看第二步
赋值表达式从右向左执行
y
被重新赋值为typeof x
的结果,也就是undefined
x
被赋值为右边表达式(y = typeof x
)的结果,也就是undefined
问题五
(function f(f){ return typeof f();//"number" })(function(){ return 1; });
直接上注释解释:
(function f(f){ //这里的f是传入的参数function(){ return 1; } //执行的结果自然是1 return typeof f(); //所以根据问题一的表格我们知道,typeof 1结果是"number" })(function(){ return 1; });
问题六
var foo = { bar: function() { return this.baz; }, baz: 1 }; (function(){ return typeof arguments[0]();//"undefined" })(foo.bar);
这里你可能会误以为最终结果是number
。向函数中传递参数可以看作是一种赋值,所以arguments[0]
得到是是真正的bar
函数的值,而不是foo.bar
这个引用,那么自然this
也就不会指向foo
,而是window
了。
问题七
var foo = { bar: function(){ return this.baz; }, baz: 1 } typeof (f = foo.bar)();//"undefined"
这和上一题是一样的问题,(f = foo.bar)
返回的就是bar
的值,而不是其引用,那么this
也就指的不是foo
了。
问题八
var f = (function f(){ return '1'; }, function g(){ return 2; })(); typeof f;//"number"
逗号操作符 对它的每个操作对象求值(从左至右),然后返回最后一个操作对象的值
所以(function f(){ return '1'; }, function g(){ return 2; })
的返回值就是函数g
,然后执行她,那么结果是2
;最后再typeof 2
,根据问题一的表格,结果自然是number
问题九
var x = 1; if (function f(){}) { x += typeof f; } x;//"1undefined"
这个问题的关键点,我们在问题二中谈到过,function expression
中的函数名f
是不能在函数体外部访问的
问题十
var x = [typeof x, typeof y][1]; typeof typeof x;//"string"
因为没有声明过变量
y
,所以typeof y
返回"undefined"
将
typeof y
的结果赋值给x
,也就是说x
现在是"undefined"
然后
typeof x
当然是"string"
最后
typeof "string"
的结果自然还是"string"
问题十一
(function(foo){ return typeof foo.bar;//"undefined" })({ foo: { bar: 1 } });
这是个纯粹的视觉诡计,上注释
(function(foo){ //这里的foo,是{ foo: { bar: 1 } },并没有bar属性哦。 //bar属性是在foo.foo下面 //所以这里结果是"undefined" return typeof foo.bar; })({ foo: { bar: 1 } });
问题十二
(function f(){ function f(){ return 1; } return f();//2 function f(){ return 2; } })();
通过function declaration
声明的函数甚至可以在声明之前使用,这种特性我们称之为hoisting。于是上述代码其实是这样被运行环境解释的:
(function f(){ function f(){ return 1; } function f(){ return 2; } return f(); })();
问题十三
function f(){ return f; } new f() instanceof f;//false
当代码new f()
执行时,下面事情将会发生:
一个新对象被创建。它继承自
f.prototype
构造函数
f
被执行。执行的时候,相应的传参会被传入,同时上下文(this
)会被指定为这个新实例。new f
等同于new f()
,只能用在不传递任何参数的情况。如果构造函数返回了一个“对象”,那么这个对象会取代整个
new
出来的结果。如果构造函数没有返回对象,那么new
出来的结果为步骤1创建的对象,
ps:一般情况下构造函数不返回任何值,不过用户如果想覆盖这个返回值,可以自己选择返回一个普通对象来覆盖。当然,返回数组也会覆盖,因为数组也是对象。
于是,我们这里的new f()
返回的仍然是函数f
本身,而并非他的实例
问题十四
with (function(x, undefined){}) length;//2
with
语句将某个对象添加的作用域链的顶部,如果在statement
中有某個未使用命名空间的变量,跟作用域链中的某個属性同名,則這個变量将指向這個属性值。如果沒有同名的属性,则将拋出ReferenceError
异常。
OK,现在我们来看,由于function(x, undefined){}
是一个匿名函数表达式,是函数,就会有length
属性,指的就是函数的参数个数。所以最终结果就是2
了
写在最后
有人觉得这些题坑爹,也有人觉得开阔了眼界,见仁见智吧。但有一件事是真的,无论你是否坚定的实践派,缺了理论基础,也铁定走不远 - 你永远不会见到哪个熟练的技术工人突然成了火箭专家。
看文档、读标准、结合实践,才是同志们的决胜之道。
以上就是关于14 个折磨人的 JavaScript 面试题的代码示例详细分析的内容,更多相关内容请关注PHP中文网(www.php.cn)!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











WebSocket 및 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법 소개: 지속적인 기술 개발로 음성 인식 기술은 인공 지능 분야의 중요한 부분이 되었습니다. WebSocket과 JavaScript를 기반으로 한 온라인 음성 인식 시스템은 낮은 대기 시간, 실시간, 크로스 플랫폼이라는 특징을 갖고 있으며 널리 사용되는 솔루션이 되었습니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법을 소개합니다.

WebSocket과 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 서론: 인터넷 기술의 급속한 발전과 함께 실시간 모니터링 시스템이 다양한 분야에서 널리 활용되고 있다. 실시간 모니터링을 구현하는 핵심 기술 중 하나는 WebSocket과 JavaScript의 조합입니다. 이 기사에서는 실시간 모니터링 시스템에서 WebSocket 및 JavaScript의 적용을 소개하고 코드 예제를 제공하며 구현 원칙을 자세히 설명합니다. 1. 웹소켓 기술

JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법 소개: 인터넷의 대중화와 기술의 발전으로 점점 더 많은 레스토랑에서 온라인 주문 서비스를 제공하기 시작했습니다. 실시간 온라인 주문 시스템을 구현하기 위해 JavaScript 및 WebSocket 기술을 사용할 수 있습니다. WebSocket은 TCP 프로토콜을 기반으로 하는 전이중 통신 프로토콜로 클라이언트와 서버 간의 실시간 양방향 통신을 실현할 수 있습니다. 실시간 온라인 주문 시스템에서는 사용자가 요리를 선택하고 주문을 하면

WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법 오늘날의 디지털 시대에는 점점 더 많은 기업과 서비스에서 온라인 예약 기능을 제공해야 합니다. 효율적인 실시간 온라인 예약 시스템을 구현하는 것이 중요합니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. WebSocket이란 무엇입니까? WebSocket은 단일 TCP 연결의 전이중 방식입니다.

JavaScript 및 WebSocket: 효율적인 실시간 일기 예보 시스템 구축 소개: 오늘날 일기 예보의 정확성은 일상 생활과 의사 결정에 매우 중요합니다. 기술이 발전함에 따라 우리는 날씨 데이터를 실시간으로 획득함으로써 보다 정확하고 신뢰할 수 있는 일기예보를 제공할 수 있습니다. 이 기사에서는 JavaScript 및 WebSocket 기술을 사용하여 효율적인 실시간 일기 예보 시스템을 구축하는 방법을 알아봅니다. 이 문서에서는 특정 코드 예제를 통해 구현 프로세스를 보여줍니다. 우리

사용법: JavaScript에서 insertBefore() 메서드는 DOM 트리에 새 노드를 삽입하는 데 사용됩니다. 이 방법에는 삽입할 새 노드와 참조 노드(즉, 새 노드가 삽입될 노드)라는 두 가지 매개 변수가 필요합니다.

JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법, 특정 코드 예제가 필요합니다. 서문: 웹 개발에서는 서버와의 데이터 상호 작용이 종종 포함됩니다. 서버와 통신할 때 반환된 HTTP 상태 코드를 가져와서 작업의 성공 여부를 확인하고 다양한 상태 코드에 따라 해당 처리를 수행해야 하는 경우가 많습니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법과 몇 가지 실용적인 코드 예제를 제공합니다. XMLHttpRequest 사용

JavaScript는 웹 개발에 널리 사용되는 프로그래밍 언어인 반면 WebSocket은 실시간 통신에 사용되는 네트워크 프로토콜입니다. 두 가지의 강력한 기능을 결합하면 효율적인 실시간 영상 처리 시스템을 만들 수 있습니다. 이 기사에서는 JavaScript와 WebSocket을 사용하여 이 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 첫째, 실시간 영상처리 시스템의 요구사항과 목표를 명확히 할 필요가 있다. 실시간 이미지 데이터를 수집할 수 있는 카메라 장치가 있다고 가정해 보겠습니다.
