In the IT world, a large number of javascript developers are needed. If the role best showcases your abilities, there are many opportunities to switch companies and increase your salary. But before you can be accepted into a company, you need to demonstrate your skills in order to pass the interview process. In this article, I’ll show you five typical questions.
Question 1: Scope
Think about the following code:
(function() { var a = b = 5; })(); console.log(b);
What will the console print out?
Answer
The above code will print out 5.
The trap of this problem is that in the immediately executed function expression (IIFE), there are two names, but the variable is declared through the keyword var. This means that a is a local variable of this function. In contrast, b is a global variable belonging to this function.
Another trap in this problem is that he did not use "strict mode" ('use strict';) in the function. If strict mode is turned on, the code will report an Uncaught ReferenceError: b is not defined. Remember strict mode requirements, you need to explicitly reference global variables if this is expected behavior. Therefore, you need to write like this:
(function() { 'use strict'; var a = window.b = 5; })(); console.log(b);
Question 2: Creating a “native” method
Define a repeatify function on the String object. This function accepts an integer parameter to specify how many times the string needs to be repeated. This function requires a string to be repeated a specified number of times. For example:
`console.log('hello'.repeatify(3));``
should print hellohellohello .
Answer
A possible implementation is as follows:
String.prototype.repeatify = String.prototype.repeatify || function(times) { var str = ''; for (var i = 0; i < times; i++) { str += this; } return str; };
This question tested the development Personnel’s understanding of inheritance in JavaScript and the prototype attribute. This also verifies that developers have the ability to extend native data type functions (although they should not do so).
Another important point here is to show that you realize how to do it without overriding functions that may already be defined. This requires determining that the function does not exist before customizing the function.
`String.prototype.repeatify = String.prototype.repeatify || function(times) {/* code here */};``
This trick is useful when you are asked to shim a javascript function.
Question 3: Hoisting variables (Hoisting)
What will be the result of executing the following code? Why is this happening?
function test() { console.log(a); console.log(foo()); var a = 1; function foo() { return 2; } } test();
Answer
The execution result of this code is undefined and 2.
The reason for this result is that both variables and functions are hoisted. Therefore, at that time a was printed, it existed in the function (that is, it was declared), but it was still undefined . In other words, the code above and the code below are identical.
function test() { var a; function foo() { return 2; } console.log(a); console.log(foo()); a = 1; } test();
Question 4: How does this work in javascript
What is the result of the following code? Please explain your answer.
var fullname = 'John Doe'; var obj = { fullname: 'Colin Ihrig', prop: { fullname: 'Aurelio De Rosa', getFullname: function() { return this.fullname; } } }; console.log(obj.prop.getFullname()); var test = obj.prop.getFullname; console.log(test());
Answer
The code prints Aurelio De Rosa and John Doe. The reason is that in JavaScript, the context of a function, which is referenced by the this keyword, depends on how the function is called, not how it is defined.
In the first console.log() call, getFullname() is called as a function of obj.prop. Therefore, the context here points to the latter and the function returns the fullname property of the object. In contrast, when getFullname() is specified as a variable of test , that context points to the global object (window). Because test is equivalent to being set as a property of the global object. For this reason, the function returns a fullname property of window, which in this case is set on the first line of the code snippet.
Issue 5: call() and apply()
Fix the previous problem and let the last console.log() print out Aurelio De Rosa.
Answer
This question can force function context through function call() or apply(). If you don't know the difference between call() and apply(), I recommend reading the article What are the differences between function.call and function.apply? . In the following code, I will use call(), but in this case apply() can also achieve the same result:
`console.log(test.call(obj.prop));``
Conclusion
In this article, we discuss Here are five typical questions asked in interviews to test JavaScript developers. The actual questions from the interviews may vary, but the concepts and topics covered are usually very similar. I hope you have fun testing your abilities. In case you don't know all the answers, don't worry: there's nothing you can't solve without learning and experience.
If you were asked other interesting questions during the interview, don’t hesitate to share them with us. This will help a lot of developers.
The above is the detailed content of Five typical JavaScript interview questions. For more information, please follow other related articles on the PHP Chinese website!

Python is more suitable for beginners, with a smooth learning curve and concise syntax; JavaScript is suitable for front-end development, with a steep learning curve and flexible syntax. 1. Python syntax is intuitive and suitable for data science and back-end development. 2. JavaScript is flexible and widely used in front-end and server-side programming.

Python and JavaScript have their own advantages and disadvantages in terms of community, libraries and resources. 1) The Python community is friendly and suitable for beginners, but the front-end development resources are not as rich as JavaScript. 2) Python is powerful in data science and machine learning libraries, while JavaScript is better in front-end development libraries and frameworks. 3) Both have rich learning resources, but Python is suitable for starting with official documents, while JavaScript is better with MDNWebDocs. The choice should be based on project needs and personal interests.

The shift from C/C to JavaScript requires adapting to dynamic typing, garbage collection and asynchronous programming. 1) C/C is a statically typed language that requires manual memory management, while JavaScript is dynamically typed and garbage collection is automatically processed. 2) C/C needs to be compiled into machine code, while JavaScript is an interpreted language. 3) JavaScript introduces concepts such as closures, prototype chains and Promise, which enhances flexibility and asynchronous programming capabilities.

Different JavaScript engines have different effects when parsing and executing JavaScript code, because the implementation principles and optimization strategies of each engine differ. 1. Lexical analysis: convert source code into lexical unit. 2. Grammar analysis: Generate an abstract syntax tree. 3. Optimization and compilation: Generate machine code through the JIT compiler. 4. Execute: Run the machine code. V8 engine optimizes through instant compilation and hidden class, SpiderMonkey uses a type inference system, resulting in different performance performance on the same code.

JavaScript's applications in the real world include server-side programming, mobile application development and Internet of Things control: 1. Server-side programming is realized through Node.js, suitable for high concurrent request processing. 2. Mobile application development is carried out through ReactNative and supports cross-platform deployment. 3. Used for IoT device control through Johnny-Five library, suitable for hardware interaction.

I built a functional multi-tenant SaaS application (an EdTech app) with your everyday tech tool and you can do the same. First, what’s a multi-tenant SaaS application? Multi-tenant SaaS applications let you serve multiple customers from a sing

This article demonstrates frontend integration with a backend secured by Permit, building a functional EdTech SaaS application using Next.js. The frontend fetches user permissions to control UI visibility and ensures API requests adhere to role-base

JavaScript is the core language of modern web development and is widely used for its diversity and flexibility. 1) Front-end development: build dynamic web pages and single-page applications through DOM operations and modern frameworks (such as React, Vue.js, Angular). 2) Server-side development: Node.js uses a non-blocking I/O model to handle high concurrency and real-time applications. 3) Mobile and desktop application development: cross-platform development is realized through ReactNative and Electron to improve development efficiency.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Atom editor mac version download
The most popular open source editor

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

Dreamweaver Mac version
Visual web development tools

Notepad++7.3.1
Easy-to-use and free code editor