search
HomeWeb Front-endJS TutorialFive typical JavaScript interview questions

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 = &#39;John Doe&#39;;
var obj = {
   fullname: &#39;Colin Ihrig&#39;,
   prop: {
      fullname: &#39;Aurelio De Rosa&#39;,
      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!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Python vs. JavaScript: The Learning Curve and Ease of UsePython vs. JavaScript: The Learning Curve and Ease of UseApr 16, 2025 am 12:12 AM

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 vs. JavaScript: Community, Libraries, and ResourcesPython vs. JavaScript: Community, Libraries, and ResourcesApr 15, 2025 am 12:16 AM

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.

From C/C   to JavaScript: How It All WorksFrom C/C to JavaScript: How It All WorksApr 14, 2025 am 12:05 AM

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.

JavaScript Engines: Comparing ImplementationsJavaScript Engines: Comparing ImplementationsApr 13, 2025 am 12:05 AM

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.

Beyond the Browser: JavaScript in the Real WorldBeyond the Browser: JavaScript in the Real WorldApr 12, 2025 am 12:06 AM

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.

Building a Multi-Tenant SaaS Application with Next.js (Backend Integration)Building a Multi-Tenant SaaS Application with Next.js (Backend Integration)Apr 11, 2025 am 08:23 AM

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

How to Build a Multi-Tenant SaaS Application with Next.js (Frontend Integration)How to Build a Multi-Tenant SaaS Application with Next.js (Frontend Integration)Apr 11, 2025 am 08:22 AM

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: Exploring the Versatility of a Web LanguageJavaScript: Exploring the Versatility of a Web LanguageApr 11, 2025 am 12:01 AM

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.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat Commands and How to Use Them
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

MinGW - Minimalist GNU for Windows

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

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor