Below is the list of JavaScript Interview Questions and Answers
No. | Questions |
---|---|
1 | What are the possible ways to create objects in JavaScript? |
2 | What is prototype chain? |
There are many ways to create objects in javascript as below,
- Object constructor:
The simpliest way to create an empty object is using Object constructor. Currently this approach is not recommended.
var object = new Object();
- Object's create method:
The create method of Object creates a new object by passing the prototype object as a parameter
var object = Object.create(null);
- Object literal syntax: The object literal syntax is equivalent to create method when it passes null as parameter
var object = {};
- Function constructor: Create any function and apply the new operator to create object instances,
function Person(name){
var object = {};
object.name=name;
object.age=21;
return object;
}
var object = new Person("Sudheer");
- Function constructor with prototype: This is similar to function constructor but it uses prototype for their properties and methods,
function Person(){}
Person.prototype.name = "Sudheer";
var object = new Person();
This is equivalent to an instance created with an object create method with a function prototype and then call that function with an instance and parameters as arguments.
function func {};
new func(x, y, z);
**(OR)**
// Create a new instance using function prototype.
var newInstance = Object.create(func.prototype)
// Call the function
var result = func.call(newInstance, x, y, z),
// If the result is a non-null object then use it otherwise just use the new instance.
console.log(result && typeof result === 'object' ? result : newInstance);
- ES6 Class syntax: ES6 introduces class feature to create the objects
class Person {
constructor(name) {
this.name = name;
}
}
var object = new Person("Sudheer");
- Singleton pattern: A Singleton is an object which can only be instantiated one time. Repeated calls to its constructor return the same instance and this way one can ensure that they don't accidentally create multiple instances.
var object = new function(){
this.name = "Sudheer";
}
Prototype chaining is used to build new types of objects based on existing ones. It is similar to inheritance in a class based language. The prototype on object instance is available through Object.getPrototypeOf(object) or proto property whereas prototype on constructors function is available through object.prototype.
Call: The call() method calls a function with a given this value and arguments provided individually Apply:
JSON is a text-based data format following JavaScript object syntax, which was popularized by Douglas Crockford. It is useful when you want to transmit data across a network and it is basically just a text file with an extension of .json, and a MIME type of application/json Parsing: **Converting a string to a native object
JSON.parse(text)
Stringification: **converting a native object to a string so it can be transmitted across the network
JSON.stringify(object)