5 JavaScript Technical Interview Questions That You Should Be Prepared For

Tabredeepbie
13 min readDec 19, 2020

--

1. How JavaScript different from other languages

1.1) JS is JIT compiled

While other languages (i.e., C, Java, C#) are compiled in advance, JS is interpreted and sometimes compiled at runtime with a just-in-time (JIT) compiler.

JavaScript skips <compiler> && <ByteCode> steps.

Java Example Compile steps below:

1.2) JS is Dynamically typed

http://mid.actiup.com/nzm/video-clermont-v-paris-fc-v-fr-fr-1ybi-5.php
http://mileno.provecracing.com/oyv/Video-Rotherham-Derby-County-v-en-gb-zyb-.php
http://great.gruposio.es/pkm/videos-Toulouse-Le-Havre-v-en-gb-1dri-.php
http://gd.vidrio.org/ink/videos-Forest-Green-Carlisle-v-en-gb-ejo-.php
http://mileno.provecracing.com/oyv/video-Rotherham-Derby-County-v-en-gb-nkg-.php
https://cartaodosus.info/video.php?video=Video-Borussia-Monchengladbach-Hoffenheim-1899-v-en-gb-tfg-.php
http://mid.actiup.com/nzm/videos-clermont-v-paris-fc-v-fr-fr-1aqr-14.php
http://great.gruposio.es/pkm/v-ideos-Toulouse-Le-Havre-v-en-gb-1tkr-11.php
https://test.activesilicon.com/vdl/Video-triestina-v-perugia-v-it-it-1cxd2-1.php
https://cartaodosus.info/video.php?video=Video-Borussia-Monchengladbach-Hoffenheim-1899-v-en-gb-zwo-.php
https://test.activesilicon.com/vdl/v-ideos-triestina-v-perugia-v-it-it-1jvu-2.php
http://mid.actiup.com/nzm/Video-Toulouse-Le-Havre-v-en-gb-1fja-14.php
http://great.gruposio.es/pkm/Video-Toulouse-Le-Havre-v-en-gb-1nba-13.php
http://mileno.provecracing.com/oyv/v-ideos-Rotherham-Derby-County-v-en-gb-apb-.php
http://gd.vidrio.org/ink/Video-Forest-Green-Carlisle-v-en-gb-nxt-.php
http://great.gruposio.es/pkm/v-ideos-Fiorentina-Hellas-Verona-v-en-gb-1tre-.php
https://test.activesilicon.com/vdl/videos-triestina-v-perugia-v-it-it-1pqc2-13.php
http://gd.vidrio.org/ink/Video-Forest-Green-Carlisle-v-en-gb-axs-.php
http://mileno.provecracing.com/oyv/videos-Millwall-Nottingham-Forest-v-en-gb-vme-.php
http://mid.actiup.com/nzm/Video-Toulouse-Le-Havre-v-en-gb-1oyx-6.php
https://cartaodosus.info/video.php?video=videos-Borussia-Monchengladbach-Hoffenheim-1899-v-en-gb-mnp-.php
http://amik.closa.com/unx/videos-Knockbreda-Loughgall-v-en-gb-1jck-9.php
http://mid.actiup.com/nzm/video-Toulouse-Le-Havre-v-en-gb-1pip-4.php
http://gd.vidrio.org/ink/videos-Northampton-Lincoln-v-en-gb-imk-.php
http://mileno.provecracing.com/oyv/videos-Millwall-Nottingham-Forest-v-en-gb-xdf-.php
https://test.activesilicon.com/vdl/Video-triestina-v-perugia-v-it-it-1tnz-12.php
http://mileno.provecracing.com/oyv/videos-Millwall-Nottingham-Forest-v-en-gb-hvt-.php
https://cartaodosus.info/video.php?video=video-borussia-mg-v-hoffenheim-1899-v-de-de-1pgj-9.php
http://mid.actiup.com/nzm/video-Fiorentina-Hellas-Verona-v-en-gb-1kbq-4.php
http://gd.vidrio.org/ink/v-ideos-Northampton-Lincoln-v-en-gb-wzt-.php
http://amik.closa.com/unx/Video-piacenza-v-pergolettese-v-it-it-1ckj-10.php
https://test.activesilicon.com/vdl/Video-triestina-v-perugia-v-it-it-1kqp2-6.php
http://mileno.provecracing.com/oyv/video-Stoke-Blackburn-v-en-gb-did-.php
http://mid.actiup.com/nzm/Video-Fiorentina-Hellas-Verona-v-en-gb-1tri-11.php
http://gd.vidrio.org/ink/video-Northampton-Lincoln-v-en-gb-vza-.php
https://cartaodosus.info/video.php?video=Video-borussia-mg-v-hoffenheim-1899-v-de-de-1iqv-9.php
http://amik.closa.com/unx/video-piacenza-v-pergolettese-v-it-it-1eag-19.php
http://mileno.provecracing.com/oyv/videos-Stoke-Blackburn-v-en-gb-xds-.php
http://mid.actiup.com/nzm/videos-Fiorentina-Hellas-Verona-v-en-gb-1hxl-17.php
http://gd.vidrio.org/ink/Video-Luton-Town-Bournemouth-v-en-gb-wlv-.php
https://test.activesilicon.com/vdl/videos-giana-erminio-v-olbia-v-it-it-1oeq-11.php
http://amik.closa.com/unx/v-ideos-piacenza-v-pergolettese-v-it-it-1kau-8.php
https://cartaodosus.info/video.php?video=v-ideos-borussia-mg-v-hoffenheim-1899-v-de-de-1meh-18.php
http://amik.closa.com/unx/Video-piacenza-v-pergolettese-v-it-it-1itq2-5.php
http://mileno.provecracing.com/oyv/v-ideos-Stoke-Blackburn-v-en-gb-vfh-.php
http://gd.vidrio.org/ink/Video-Luton-Town-Bournemouth-v-en-gb-kex-.php
https://test.activesilicon.com/vdl/videos-giana-erminio-v-olbia-v-it-it-1yhf2-17.php
https://test.activesilicon.com/vdl/videos-giana-erminio-v-olbia-v-it-it-1xgr-13.php
http://mileno.provecracing.com/oyv/video-Mansfield-Southend-v-en-gb-exc-.php
http://amik.closa.com/unx/Video-piacenza-v-pergolettese-v-it-it-1tyo-9.php
http://mid.actiup.com/nzm/Video-fiorentina-v-hellas-verona-v-it-it-1chz-2.php
http://gd.vidrio.org/ink/video-Luton-Town-Bournemouth-v-en-gb-xej-.php
http://gd.vidrio.org/ink/Video-Ballinamallard-United-Newry-City-AFC-v-en-gb-nip-.php
https://cartaodosus.info/video.php?video=Video-Mainz-05-Werder-Bremen-v-en-gb-njy-.php
http://mileno.provecracing.com/oyv/v-ideos-Mansfield-Southend-v-en-gb-uwt-.php
http://mid.actiup.com/nzm/Video-fiorentina-v-hellas-verona-v-it-it-1duk2-19.php
https://test.activesilicon.com/vdl/videos-giana-erminio-v-olbia-v-it-it-1mnv2-5.php
http://mileno.provecracing.com/oyv/v-ideos-Mansfield-Southend-v-en-gb-kcl-.php
http://gd.vidrio.org/ink/v-ideos-Ballinamallard-United-Newry-City-AFC-v-en-gb-zrn-.php
https://test.activesilicon.com/vdl/Video-giana-erminio-v-olbia-v-it-it-1djv2-6.php
http://amik.closa.com/unx/v-ideos-pogon-szczecin-v-zaglebie-lubin-v-pl-pl-1qbv-14.php
https://cartaodosus.info/video.php?video=videos-Mainz-05-Werder-Bremen-v-en-gb-svg-.php
http://mid.actiup.com/nzm/Video-fiorentina-v-hellas-verona-v-it-it-1lry2-9.php
https://cartaodosus.info/video.php?video=video-Mainz-05-Werder-Bremen-v-en-gb-nbn-.php
http://mileno.provecracing.com/oyv/videos-Swindon-Charlton-v-en-gb-ldz-.php
http://amik.closa.com/unx/Video-pogon-szczecin-v-zaglebie-lubin-v-pl-pl-1trw-5.php
http://gd.vidrio.org/ink/video-Ballinamallard-United-Newry-City-AFC-v-en-gb-yhe-.php
http://mid.actiup.com/nzm/v-ideos-fiorentina-v-hellas-verona-v-it-it-1mbd-1.php
http://mileno.provecracing.com/oyv/videos-Swindon-Charlton-v-en-gb-xtl-.php
http://gd.vidrio.org/ink/video-Huddersfield-Town-Watford-v-en-gb-xdg-.php
http://mid.actiup.com/nzm/video-fiorentina-v-hellas-verona-v-it-it-1itq2-11.php
http://amik.closa.com/unx/Video-pogon-szczecin-v-zaglebie-lubin-v-pl-pl-1xgu-2.php
https://test.activesilicon.com/vdl/Video-ravenna-v-imolese-v-it-it-1upr-14.php
https://cartaodosus.info/video.php?video=videos-mainz-05-v-werder-v-de-de-1klx-9.php
http://gd.vidrio.org/ink/v-ideos-Huddersfield-Town-Watford-v-en-gb-pkh-.php
http://mid.actiup.com/nzm/Video-Barry-Town-Newi-Cefn-Druids-v-en-gb-1gia-11.php
http://mileno.provecracing.com/oyv/Video-Swindon-Charlton-v-en-gb-vhd-.php
http://amik.closa.com/unx/Video-pogon-szczecin-v-zaglebie-lubin-v-pl-pl-1bml-12.php
https://cartaodosus.info/video.php?video=videos-mainz-05-v-werder-v-de-de-1res-18.php
https://test.activesilicon.com/vdl/v-ideos-ravenna-v-imolese-v-it-it-1kpf-14.php
http://mid.actiup.com/nzm/v-ideos-Barry-Town-Newi-Cefn-Druids-v-en-gb-1lny-12.php
https://cartaodosus.info/video.php?video=v-ideos-mainz-05-v-werder-v-de-de-1ylf-5.php
http://mileno.provecracing.com/oyv/Video-Grimsby-Town-Scunthorpe-v-en-gb-kij-.php
http://amik.closa.com/unx/videos-pogon-szczecin-v-zaglebie-lubin-v-pl-pl-1xsz-3.php
https://test.activesilicon.com/vdl/video-ravenna-v-imolese-v-it-it-1mpf2-17.php
http://gd.vidrio.org/ink/Video-Huddersfield-Town-Watford-v-en-gb-phx-.php
http://mileno.provecracing.com/oyv/v-ideos-Grimsby-Town-Scunthorpe-v-en-gb-yej-.php
https://test.activesilicon.com/vdl/videos-ravenna-v-imolese-v-it-it-1skc-17.php
http://mid.actiup.com/nzm/video-Barry-Town-Newi-Cefn-Druids-v-en-gb-1jmf-1.php
http://gd.vidrio.org/ink/videos-Southampton-Man-City-v-en-gb-qzl-.php
http://gd.vidrio.org/ink/video-Southampton-Man-City-v-en-gb-daz-.php
https://test.activesilicon.com/vdl/v-ideos-ravenna-v-imolese-v-it-it-1ixc-6.php
http://mileno.provecracing.com/oyv/Video-Grimsby-Town-Scunthorpe-v-en-gb-glr-.php
http://amik.closa.com/unx/videos-eni-malatiaspor-v-kasympasha-v-yt2-1cne-1.php
http://mileno.provecracing.com/oyv/Video-Wycombe-Wanderers-Queens-Park-Rangers-v-en-gb-bxz-.php
http://amik.closa.com/unx/v-ideos-eni-malatiaspor-v-kasympasha-v-yt2-1qvg-15.php
http://mid.actiup.com/nzm/Video-molde-v-sarpsborg-08-v-no-no-1qnv-15.php
http://gd.vidrio.org/ink/v-ideos-Southampton-Man-City-v-en-gb-lhz-.php
http://gd.vidrio.org/ink/Video-Southampton-Manchester-City-v-en-gb-dyj-.php
https://cartaodosus.info/video.php?video=Video-The-New-Saints-Penybont-v-en-gb-esb-.php

In JS, types can be changed or reassigned dynamically.

1.3) JS is Classless language

*ECMAScript 2015, also known as ES6, introduced JavaScript Classes.

JavaScript is a classless language; classes can be simulated. Although JavaScript does not have classes, it does have objects, which then defines the language to be object oriented. For example, inheritance can be used by using prototypes, also functions themselves are objects because they have their own properties and methods.

Cat object function can be working as Class with `new` keyword:

1.4) Variable scope

There are no such things as public, private or protected variables: These can be simulated.

You can simulated public, private or protected variable using scopes.

2. What is a REST(ful) API?

It’s architectural style for distributed systems and REST is acronym for REpresentational State Transfer.

An API is an application programming interface. It is a set of rule set of rules that allow programs to talk to each other. The developer creates the API on the server and allows the client to talk to it.

REST determines how the API looks like. There are 5 other guiding architectural constraints that define a RESTful system. In this article, I will go over only Uniform interface because it is a constraint that keeps the RESTful style architecture unique from most other network application architectures.

HATEOAS (Uniform interface)

HATEOAS stands for Hypertext As The Engine Of Application State. It allows the client can dynamically navigate to the appropriate resources by traversing the hypermedia(REST Resource Addressability).

HATEOAS used with specific Method (i.e., POST , GET) tells the server which task the client wants to execute. For example /customers/{id} URI path along with GET request means that the client wants to Get a specific customer.

Pros of Restful API:

  • Decouples Client and Server.
  • Uniform Interfaces helps communication between developers much easier.

Restful API vs SOAP

Summary: SOAP relies exclusively on XML to provide messaging services. This gives a benefit for SOAP that it has a standard. But its use of XML is also the drawback for SOAP because JSON is easier to use and more popular these days.

Unlike SOAP-based web services, there is no “official” standard for RESTful web APIs. This is because REST is an architectural style, while SOAP is a protocol. REST is not a standard itself, but RESTful implementations make use of standards, such as HTTP, URI, JSON, and XML.

3. How do you test code?

There are many ways you can ensure that you write quality codes. First, let’s compare unit test and end-to-end (E2E) test.

3.1) JavaScript Unit Test

Unit test tests a block of code (i.e., function) “unit” to ensure that they all run as expected. This tests allow developers to check individual areas of a program to see where(and why) errors occur.

Benefit of Unit Testing

1. It makes your project more agile. Whenever you add a new feature, you many have to change the old code. Changing a code that’s been tested already is costly and risky. However, if you run unit tests on the new code, you will be confident that the new code won’t break any old feature.

2. Helps finding bugs early in the development cycle.

Popular Unit Testing Tool

Jest

Jest is a JavaScript testing framework maintained by Facebook.

3.2) JavaScript E2E Test

End-to-End (E2E) testing is a technique used to test if the application behaves as expected. In simple terms, a software testing methodology to test an application flow from start to end. The main purpose of E2E is to simulate the real user scenario.

Popular E2E Testing Tool

Cypress.io

Fast, easy and reliable testing for anything that runs in a browser.

TDD vs. BDD

“What are you testing for?” is a great question to ask when comparing The Unit test and E2E test. In behavior driven development (BDD), you are looking for the behavior, for example, what will happen to this system under a certain condition. But in test driven development (TDD), you have a test for a method which will assert some conditions, but as the system evolves these tests may give you false results.

To simply this further, it can be written

In TDD, I don’t care much about the output. The only thing needed is to carry out the test in a particular way.

In BDD, I don’t mind how you come up with the output, only that the output has to be correct under the given condition.

Summary

BDD has evolved from TDD, as a way to eliminate the shortfalls of TDD.

Best to implement both approaches — one to support the quality of the code the developer writes, and the other to support the behavior of the system defined by the product owner.

3.3. Linters

lint, or a linter is a static code analysis tool used to flag programming errors, bugs, stylistic errors, and suspicious constructs. They scan your scripts for common issues and errors, and give you back a report with line numbers that you can use to fix things. In addition to actual bugs and errors, they also check for subjective, stylistic preferences as well.

Benefits of linters

1. Linter helps catching common mistakes and bugs easily.

2. Linter helps increase productivity by allowing colleagues to use same code styles.

Popular linters

ESLint

The custom configurations is the one of the best features of ESLint. While JSLint does not allow for configuration, which means it enforces a single style guide, ESLint is little bit more flexible.

You could adopt big IT companies’ coding style easily with using ESLint.

Google

“extends”: [“eslint:recommended”, “google”]

AirBnb

"extends": ["eslint:recommended", "airbnb"]

Standard

"extends": ["eslint:recommended", "standard"]

3.4. Online code editors

Many developers use online code editor for everyday developments & debugging and it indeed one of the best testing tools for modern developers.

jsfiddle & repl.it

Good for checking confusing JavaScript types and variable scopes.

repl.it

CodeSandbox

Good for testing SPA code (React, Vue or Angular).

Codepen

Good for testing CSS and HTML. CSS is hard to debug and find the errors because CSS often does not throw any errors.

4. What is the difference between deep copy and shallow copy?

A deep copy means that all of the values of the new variable are copied and disconnected from the original variable. A shallow copy means that certain (sub-)values are still connected to the original variable.

Shallow copy vs. deep copy in JavaScript object

Shallow copy is often times problematic when using object in JavaScript.

Shallow copy

We only change pt property of object b ( b.pt ) but object a has also changed:

In the example above, we actually made a shallow copy. This is often times problematic, since we expect the old variable to have the original values, not the changed ones.

Deep copy

There are multiple ways to make copies of objects, especially with the new expanding and improving JavaScript specification.

Deep copy — Spread operator

Introduced with ES2015, spread operator is short and simple. It spreads out all of the values into a new object.

You can also use it to merge two objects together, for example

const c = {...a, ...b}

Deep copy — Object.assign

This was mostly used before the spread operator was around. Object.assign assigns object a to empty object {}

Pitfall: Nested Objects

There is one big caveat when dealing with copying objects, which applies to both methods listed above. When you have a nested object (or array) and you copy it, nested objects inside that object will not be copied, since there are only pointers / references. Shallow copy again

Deep copy of nested objects — Spread operator

Deep copy of nested objects — Stringify & Parse

It can be very tedious to manually go through big objects and copy every nested object by hand. There is a way to copy everything without thinking. You simply stringify your object and parse it right after

5. What is Server-side rendering used for?

Server-side rendering

Server-side rendering (SSR) is the process of rendering web pages on a server and passing them to the browser (client-side), instead of rendering them in the browser. SSR sends a fully rendered page to the client; the client’s JavaScript bundle takes over and enables the SPA framework to operate

SSR vs. client-side rendering

Server-side rendering sends a fully rendered page to the client; while Client-side rendering needs to navigate to the page (router ) to have the content for the page

SSR; PROS

  • It enables pages to load faster which provides a better user experience
  • It plays an important role in SEO (search engine optimization) and correctly indexes webpages because Google favors web pages with faster load time

SSR; CONS

  • Rendering a big application on the server-side can be very time consuming and it may increase the loading time due to it being a single bottleneck
  • Performance issue if the end user is using a slow internet connection (i.e., mobile connection) or underpowered device (i.e., older generation mobile devices)

Next.js (SSR for React)

Next.js is is an open-source React front-end development web framework that enables functionality such as server-side rendering and generating static websites for React based web application

npm install next react react-dom
# or
yarn add next react react-dom
yarn create next-app <project-name>
# or
npx create-next-app <project-name>

Nuxt.js (SSR for Vue)

Nuxt.js is a free and open source web application framework based on Vue.js to build SSR

npx create-nuxt-app <project-name>

My thoughts on SSR

Many companies will ask your experiences with SSR such as Next.js (React) or Nuxt.js (Vue). If you have personal / professional experiences of using SSR, you are lucky 🙌 that you have experiences to brag about. But if you don’t, I think you still do not need to worry too much or build a new app using SSR. I think SSR is still the **optional** skill for Front-end developer like data visualization such as D3.js

It’s good to have the experiences with SSR, but if you don’t, just learn about SSR and how it is different from Client Side rendering. Just show that you know SSR and you are capable of learning more.

Thank you for reading and hope that it helps you preparing for the upcoming interviews.

Photo by Jon Tyson on Unsplash

--

--

Tabredeepbie
0 Followers

Writing mostly to myself. Sharing some of it with you. Hope it helps.