17 min to read
JavaScript is used to build complex, desktop-like web applications. One of the famous languages that help in building server-side software. It has gained huge popularity after the launch of Node.js It is a versatile and dynamic language. Let’s understand the details of this language and have an interesting Q&A on it.
Java is an object-oriented programming language; JavaScript is an object-based scripting language. Java code can work on any platform including the web browser. However, JavaScript is written just for web browsers. Among other things, Java demands more memory. It is strongly typed and asks all variables to have a declared type. In contrast to JavaScript which is lightweight and weakly typed.
The data types supported by JavaScript are-
Yes, JavaScript is a case-sensitive language. One needs to make sure that- language keywords, function names, variables, and any other markers need to be consistent in code.
Yes! An anonymous function can be assigned to a variable. Yes, it is a possibility to pass it as an argument to another function.
The scope of a variable refers to the region of your program, where a variable is visible and could be accessible. JavaScript variables have two scopes.
• Global Variables − A global variable has a large scope meaning it is seen everywhere in your JavaScript code.
• Local Variables − A local variable will be visible only where it is defined inside a function. Function parameters are always local to that function.
The JavaScript keyword ‘this’ refers to the object it belongs to. It will have a different value depending on where it will be used. In a method, ‘this’ caters to the owner object, and in a function, ‘this’ mentions the global object.
A callback is a plain JavaScript function that is passed to some method as an argument or option. The name is derived as the function gets implemented after another function has finished its implementation. In JS, functions are first-class objects. Due to this, functions can seek functions as arguments as well. It can also be returned by other functions.
When naming variables in JavaScript, one needs to keep certain rules in mind-
The Type of Operator is used to get the data type of its operand. The operand can be either a literal or a data structure such as a variable, a function, or an object. It is a unary operator that is placed before its single operand, which can be of any type. Its value is a string indicating the data type of the operand.
The easiest way to create a cookie is to designate a string value to the document. cookie object, which looks like this-
Syntax :
document.cookie = "key1 = value1; key2 = value2; expires = date";
Reading a cookie is like writing one. The reason is the value of the document. cookie object is the cookie. Hence, one can use this string whenever one wants to access the cookie.
If you want to delete a cookie so that upcoming attempts to read the cookie in JS return nothing, you need to set the expiration date to a time in the past. One should define the cookie path to ensure you delete the right cookie. Some browsers will not let you delete a cookie if you don’t specify the path.
Hoisting is the default behavior of JS where all the variable and function declarations are moved to the highest echelon, irrespective of where the variables and functions are declared. The scope can be both local and global.
Example:
hoistedVariable = 3;
console.log(hoistedVariable);
// outputs 3 even when the variable is declared after it is initialized
var hoistedVariable;
// Variable initializations are not hoisted, only variable declarations are hoisted
Example:
var x;
console.log(x);
// Outputs "undefined" since the initialization of "x" is not hoisted
x = 23;
A closure is an inner function that admits to the variables that belong to the outer (enclosing) function’s scope chain. There are three ways in which the closure can access variables; specifically:
DOM event delegation is used for responding to user events via a single parent rather than each child node. With it, you can bind an event handler to a common parent element that will handle any event happening to one of its children.
Event bubbling and capturing are two ways via which events can be handled in the HTML DOM API. When an event occurs in an element and its parent also registers a handle for the same event, the event propagation model will decide which element should receive the event first.
By default, addEventListener uses bubbling- here the event is first captured in the innermost element and propagates to outer elements.
While in the capturing phase, the opposite happens; the event is captured in the outermost element first and propagates to the inner elements.
Attributes- It presents you with more info about an element like type, value, id, etc.
Property- Used as the value assigned to the property like type=” text”, value=’Name’ etc.
This is the list of ways, through which HTML elements can be accessed in a JavaScript code:
(i) getElementById(‘name): Gets an element by its ID name
(ii) getElementsByClass(‘class name): Gets all the elements that have the given class name.
(iii) getElementsByTagName(‘tag name): Gets all the elements that have the given tag name.
(iv) querySelector(): This function takes a CSS style selector and returns the first selected element.
There are 3 different ways when the following can take place:
An inline function is a JavaScript function, designated to a variable created at runtime. One can tell the difference between Inline Functions and Anonymous as an inline function is designated to a variable. It can be easily used again.
When one needs JavaScript for a function, one can either have the script embedded into the page one is working on, or have it placed in a separate file that one can use when required. This is the difference between an internal script and an external script.
The 3 main techniques for defining a variable in JavaScript are:
Typed Language is a language where the values are assigned with values and not with variables. So, there are two kinds of typed language:
JavaScript is a dynamically typed language. Therefore, here, the variable type is properly checked while run-time. In contrast to statically typed language, where the specific variable type is properly checked while the compilation time.
Local Storage – Here, the data is not sent to the server reversely for each HTTP request (images, CSS, HTML, JavaScript, etc) – lessening the amount of traffic between the server and the client. However, it stays until it is manually cleared via a program or some settings.
Session Storage – It resembles local storage, but the difference is the data which is stored in local storage has no expiration time and the data stored in session storage immediately gets cleared when the session of the page terminates. Moreover, the session storage will leave when the browser is off.
The prime difference between the “==” and “===” operators is that “==” compares the variable by making a type correction. For instance, if you compare a number with a string with a numeric literal, == permits that, however, === doesn’t permit that, because it not only checks the value yet also the kind of two variables if two variables are not of the same type “===” return false, while “==” returns true.
Undefined refers to a variable that has been declared yet has not been assigned a specific value. Besides, null refers to an assignment value and it can be assigned to a variable as a demonstration of no value. Moreover, undefined and null are two distinct kinds: a null is an object while undefined is itself a type.
Undeclared variables are not visible in a program and are not declared too. If a program puts an effort to read the value of an undeclared variable, then a runtime error is experienced. Certainly, undefined variables are declared in the program yet have not been provided any value. So, if the program wishes to read the value of an undefined variable, an undefined value is instantly returned.
Currying is an advanced technique to transform a function of arguments n, to n functions of one or fewer arguments.
Example of a curried
function:
function add(a) {
return function(b) {
return a + b;
}
}
add(3)(4)
For Example,
if we have a
function f(a, b), then the
function after currying, will be transformed to f(a)(b).With a currying technique, we do not modify the functions ' functionality, we just modify the way it is called on.
Let 's look at currying in action:
function multiply(a, b) {
return a * b;
}
function currying(fn) {
return function(a) {
return function(b) {
return fn(a, b);
}
}
}
var curriedMultiply = currying(multiply);
multiply(4, 3); // Returns 12
curriedMultiply(4)(3); // Also returns 12
As mentioned in the above, we have altered the
function multiply(a, b) to a
function curriedMultiply, which demands one parameter at a time.
First-class functions are functions that you can:
Lexical scoping refers to the available variables in the location of a function’s definition.
Dynamic scoping refers to the available variables in the location of a function’s invocation.
There are three types of errors:
We use the push method to add or affix one or more elements to an array end. However, when we use the push method, one can attach several elements by passing various arguments.
The Unshift method is similar to the Push method, which mainly works at the commencement of the array. We use this method to add one or more elements at the start of the array.
JavaScript permits DOM elements to be fixed inside each other. In this case, if one clicks the handler of the child, then the handler of the parent will also operate as if it were clicked too.
ECMA Script represents guidelines and rules, while JavaScript is a scripting language used mainly for web development.
DOM stands for Document Object Model and it is a programming interface for XML and HTML documents.
When the browser attempts to render an HTML document, it instantly builds an object based on the HTML document known as DOM. With DOM, we can easily manipulate or alter several elements that are inside the HTML document.
Temporal Dead Zone is a behavior seen with variables that are declared using const and let keywords. This behavior occurs, when one tries to access a variable before it is initialized. Examples of temporal dead zone:
x = 23; // Gives reference error
let x;
function anotherRandomFunc() {
message = "Hello"; // Throws a reference error
let message;
}
anotherRandomFunc();
In the above-mentioned code, we are attempting to access variables that have not been declared yet in the functional scope and the global scope. This is called the Temporal Dead Zone.
Document: The document lies under the window's object and can also be contemplated as its property.
Window: A window in JavaScript represents a global object that holds the structure like functions, location, variables, history, etc.
Web Workers represent running scripts in background threads for the web content. The worker thread can easily execute tasks without intervening with the user interface.
Besides, they can use XMLHttpRequest to execute I/O or fetch. Once created, by posting messages to an event handler based on that code, a worker can simply send messages to the JavaScript code that created it and vice versa.
Web Workers helps you create background threads unconnected from the prime execution thread, where the logic of the user interface is usually performed. The basic benefit of this unconnectedness of workload is that inside an isolated thread and without intervening or affecting the prime thread’s usability and responsiveness, one can easily execute costly operations.
Example:
Step 1: Create a project folder and add index.html in the root of it. <
!DOCTYPE html >
<
html lang = "en" >
<
head >
<
meta charset = "UTF-8" / >
<
meta name = "viewport"
content = "width=device-width, initial-scale=1.0" / >
<
title > Club JavaScripters < /title> <
/head> <
body >
<
button > Can you click me ? < /button> <
h2 > Let 's do the party. 👯♂️</h2> <
ul id = "club" > < /ul> <
script src = "./main.js" > < /script> <
/body> <
/html>
We just created a simple HTML page with a link to our javascript file which we will create in a moment.
Step 2: So, now we will add our JavaScript code in two individual files, worker.js and main.js in the same folder.
main.js
const persons = [{
name: "Hriday",
isMember: true,
},
{
name: "Hridayesh",
isMember: false,
},
{
name: "Bob",
isMember: true,
},
{
name: "Daisy",
isMember: true,
},
]
// Our club container
const club = document.getElementById("club")
let worker
/**
* Function entry permits entry to those people who are coming to our club
*/
function entry(persons) {
persons.forEach(person => {
const {
isMember,
name
} = person
const listItem = document.createElement("li")
listItem.textContent = name
// if a person is not registered till now, register them first
if (!isMember) {
// create a new worker thread
worker = new Worker("worker.js")
// pass data to worker thread
worker.postMessage(name)
// listen to any data which is passed from the worker thread
worker.addEventListener("message", event => {
if (event.data) {
club.appendChild(listItem)
}
})
} else {
// let them in if they are registered
club.appendChild(listItem)
}
})
}
entry(persons)
worker.js
// addEventListener is directly accessible in the worker file
addEventListener("message", event => {
// extract person passed from the main thread from event object
let person = event.data
registerMember(person)
})
function registerMember(member) {
// generating membership card takes some time
let i = 0
while (i < Math.pow(10, 10)) {
i++
}
// send the result back to the main thread
postMessage(true)
close()
}
Explaination:
a.Initially, we search
for each person
if they are a member or not.And
if they are, then we permit them in .
b.If a person is not a member of the club till now, then we develop a worker thread
for it with a fresh Worker('path to worker code') and then pass that person to the worker thread with worker.postMessage() and later adding that specific person as a member after registering them.
c.To imitate the entire registration process we execute some processing with the help of a long
while loop.In reality, this could be similar to some cryptographic code, image processing or any other thing that is CPU intensive and might block the main thread and make the page unresponsive.
d.Once you have registered, the worker thread
let the main thread know about your registration by sending the data using postMessage and the main thread listens
for it using on message handler and add the person in the club i.e add to DOM.
e.Once we
finally get the result from the worker thread, we instantly close it using close().
Certainly, the behavior of “this” which is inside of an arrow function varies considerably from the general function’s “this” behavior. However, the arrow function does not show its performance context. No matter where or how it is being performed, the “this” value that is inside of an arrow function always remains the same “this” value from the outer function. In other words, the arrow function resolves “this” lexically.
In the following example, myMethod() is an outer
function of callback() arrow
function:
const myObject = {
myMethod(items) {
console.log(this); // logs myObject
const callback = () => {
console.log(this); // logs myObject
};
items.forEach(callback);
}
};
myObject.myMethod([1, 2, 3]);
"this"
value that is inside the arrow
function callback() equals to "this" of the outer
function myMethod().
"this"
resolved verbally is one of the fine characteristics of arrow functions.When using callbacks inside methods you have to be sure that the arrow
function doesn 't notify its own "this": no more const self = this or callback.bind(this) workarounds.
Contrary to a regular
function, the indirect invocation of an arrow
function using myArrowFunc.call(thisVal) or myArrowFunc.apply(thisVal) doesn 't alter the value of "this": the context value is always resolved lexically.
An IIFE (Immediately Invoked Function Expression) is a javascript function that runs just after it’s defined. The ‘( )’ at the end is responsible for calling the function.
(function() {
statements
})();
Exception handling can be done by using the try-catch block, any block of code which can throw an exception should be wrapped in the try block. The catch block is responsible for handling the exception caught.
try {
apiCall();
} catch (error) {
//error occurred in apiCall
}
Data up to a certain limit can be stored in the browser instead of the server. There are 3 types of client-side storage present in the browser 1. Cookie. 2. Local Storage. 3. Session Storage.
You can attach an event on target by using the “addEventListener” function which accepts event type and a callback function as a parameter. Whenever this event triggers, the callback function gets executed.
e.g target.addEventListener('click', function() {
//event triggered
});
Automatic conversion of one data type to another is known as implicit type coercion.
example
console.log("3" + 3). //prints 33
The integer value of 3 coerced to "3"
internally, resulting 3 + "3"
into "33".
Map: Map takes a callback and runs it against every element on the array. However, it is unique as it generates a new array based on your existing array. Example:
var sample = [1, 2, 3]
let mapped = sample.map(elem => elem * 10)
console.log(mapped);
/* output */
[10, 20, 30]
Filter: Filter lets you provide a callback for every element and check its return value. If the value is true element remains in the resulting array but if the return value is false the element will be removed from the resulting array.
Example:
var sample = [1, 2, 3]
var result = sample.filter(elem => elem !== 2)
/* output */
[1, 3]
Reduce: Reduce method of the array object is used to reduce the array to one single value.
For example, if you have to add all the elements of an array:
var sample = [1, 2, 3]
var sum = sample.reduce((sum, elem) => sum + elem)
console.log(sum)
/* output */
6
We can create an empty object by using a constructor, so checking the key length of an object doesn’t work. We have to check for its constructor as well.
Object.keys(value).length === 0 &&
value.constructor === Object;
LocalStorage is a property that allows JavaScript sites and apps to save key-value pairs in a web browser with no expiration date. This means the data stored in the browser will persist even after the browser window is closed. It provides different methods to work with:-
setItem(): Add key and value to localStorage
getItem(): Retreive fom localStorage
removeItem(): Remove an item by key from localStorage
clear(): Clear all localStorage
key(): Passed a number to retrieve the key of a localStorage
The document.querySelectorAll method will return you the novelist of all elements with the same identifier.
const allParagraph = document.querySelectorAll("p");
const allElementWithFunClass= document.querySelectorAll(".fun");
One of the most used and popular algorithms in the programming world. It is important to note there is a difference between sort() and this Quick Sort algorithm.
The Quick Sort algorithm follows Divide and Conquer approach. Now, it divides elements into smaller parts. Based on those conditions, the algorithm performs operations on those divided into smaller parts. It works well for large datasets. Let’s see how it works in a few steps
Candidates are required to clear the interview to pursue a career in JavaScript development. Numerous JavaScript interview questions and answers are posed to them.
We have compiled the list of JavaScript interview questions and answers that are most likely to be asked during the interview. Based on their expertise and other criteria, candidates may be asked anything from simple JavaScript interview questions to advanced JS interview questions.
All of the JavaScript questions for freshers and JavaScript interview questions for professional-level applicants are included in the list above. Codersera guide to JS interview questions will help you ace the interview and land your ideal JavaScript Programming job.
JavaScript is commonly used for creating web pages. It allows us to add dynamic behavior to the webpage and add special effects to the webpage. On websites, it is mainly used for validation purposes. JavaScript helps us to execute complex actions and also enables the interaction of websites with visitors.
The $ represents the jQuery Function and is actually a shorthand alias for jQuery. (Unlike in most languages, the $ symbol is not reserved, and may be used as a variable name.) It is typically used as a selector (i.e. a function that returns a set of elements found in the DOM).
There are some languages that are very safe. Your interviewer should understand Java, C, and Python, so any of those languages is totally reasonable. Other languages, particularly more readable ones are fine too. For example, Javascript and Ruby.
Tags
Are you looking for something specific?
We understand that hiring is a complex process, let’s get on a quick call.
Share
11 comments