JavaScript Interview Flashcards

1
Q

What is Scope?

A

Refers to the availability of variables in our code

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
2
Q

What is the scope of Var?

A

function scoped

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
3
Q

What is the scope of let and const ?

A

block scoped

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
4
Q

How are var declarations hoisted?

A

var declarations when hoisted they are initialized with undefined.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
5
Q

How are let and cont declarations hoisted?

A

when hoisted they are not initialized with undefined.

So, this would trigger a reference error if accessing before declaration.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
6
Q

What is Hoisting?

A

Hoisting means moving variable declarations to the top of their scope.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
7
Q

Can you redeclare variables with the let keyword

A

No, this is not possible.

Error: Syntax Error: Identifier ‘name’ has already been declared

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
8
Q

What is Lexical Scoping?

A

means that a variable defined outside a function can be accessible inside another function defined after the variable declaration.

‘this’ refers to it’s current surrounding scope and no further.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
9
Q

What is important to remember about Scope and nested functions?

A

Nested function have access to variables declared in their own scope as well as variables declared in the outer scope

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
10
Q

What are Closures?

A

A closure is the combination of a function bundled together (enclosed) with references to its surrounding state (the lexical environment).

In JavaScript, closures are created every time a function is created, at function creation time.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
11
Q

What is Function Currying?

A

Currying is a process in functional programming in which we transform a function with multiple arguments into a sequence of nesting functions that take one argument at a time

function fn(a,b,c) transformed into fn(a)(b)(c)

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
12
Q

What is ‘this’?

A

The JavaScript this keyword refers to the object it belongs to. You can set it with bind() among others.

‘this’ keyword is the execution context for a function call

It allows you to introduce reusability by allowing this value to be dynamic based on how a function is invoked

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
13
Q

What is default binding

A

If call, apply, bind are not set, JS will default to the global scope and set ‘this’ keyword to the window object.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
14
Q

Using implicit Binding, how do we know what ‘this’ is referencing?

A

When the function in invoked with the dot notation, the object to the left if that dot is what the this keyword is referencing.

Ex. person.sayMyName( )
‘this’ keyword is referencing the ‘person’ object

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
15
Q

What is the difference between call and bind methods

A

instead of invoking the function, Bind returns a new function that you can invoke whenever you wish

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
16
Q

What do you know about arrow functions?

A

Introduced in ES6
Concise Function syntax
Provides Lexical binding
Can’t be called with new keyword

Arrow functions do not bind their own “this” , instead, they inherit the one from the parent scope, which is called “lexical scoping”

17
Q

What are Higher Order Functions?

A

This is a function that can take in another function

Ex. The .map() function is a higher order function that will run a callback on every item in the array and will push each result into a new array.

18
Q

What are first class functions?

A

function that was built with the intention of being passed around to other functions. It does one specific thing, does not have side effects, and is not intended to be called directly, but rather, to be used by ‘other functions.’

19
Q

What are Callbacks?

A

is a function passed into another function as an argument to be executed later.

20
Q

What does the new keyword do?

A
  • creates a new empty object { }
  • sets the value of ‘this’ to be the new empty object
  • calls the constructor method
21
Q

What is a promise

A

A promise is an object that may produce a single value some time in the future : either a resolved value, or a reason that it’s not resolved
Pending, initial state, fulfilled, rejected

22
Q

What are the differences between == and === ?

A

a===b means that a and b are equal in both value and type.

a==b means that they are equal in value only.

23
Q

What is the difference between null and undefined.

A
Undefined means a variable has been initialized but not been assigned a value;
//var initialized
let a;
//this log will give undefined
console.log(a)

null is an assignment

//var initialized and assigned to null
let a = null;
//log will give null
console.log(a)
24
Q

Why use Promises?

A

Promises help us deal with asynch code in a far more simpler way compared to callbacks

25
Q

What two methods/functions does the Promise Object provide access to?

A

.then() - called with promise.then()
.catch() - called with promise.catch()

And you would chain these together

26
Q

What is Promise.all()

A

Allows us to query multiple APIs and preform some actions but only after all the APIS have finished loading

If one promise rejects, promise.all() will reject with an error message.

27
Q

What are Classes?

A

Classes are like a blue print. Ex. Class could be an email for several users.

Every user has a different value for an email and email is the class.

28
Q

What is a constructor function?

A

Creates new objects based upon the Class