The _______ operator can be used to unpack the values from an iterable into individual elements.
- spread
- merge
- combine
- join
The spread operator (...) in JavaScript is used to unpack elements from an iterable, such as an array, and spread them into individual elements or combine them with other elements.
What happens when you try to create a new Symbol using the new keyword?
- Error is thrown
- A new Symbol is created
- It returns an existing Symbol
- Symbols cannot be created using new
When attempting to create a Symbol using the new keyword, it results in an error. Symbols are primitive values, and using the new keyword with them is not allowed. Symbols are typically created without the new keyword.
When creating a module that provides a primary functionality along with several auxiliary functions, how should you organize the exports?
- export default PrimaryFunction; export { auxFunc1, auxFunc2 };
- export { PrimaryFunction, auxFunc1, auxFunc2 }
- export PrimaryFunction; export auxFunc1; export auxFunc2;
- export PrimaryFunction, auxFunc1, auxFunc2;
Organizing exports with a named export for the primary functionality and auxiliary functions ensures clarity and flexibility when importing in other modules.
In a class hierarchy, if a method is overridden, how can you call the method from the parent class?
- Using this.method()
- super.method()
- parent.method()
- class.method()
The 'super' keyword is used to call the overridden method from the parent class. It ensures that the overridden method in the subclass is bypassed, and the method from the parent class is invoked.
How do mixins in ES6 help in achieving multiple inheritance?
- Through Object Assignment
- Using Class Hierarchy
- Prototypal Inheritance
- Closures
Mixins in ES6 are achieved by applying the properties and methods of one object to another using object assignment. This allows a single object to inherit functionalities from multiple sources, providing a form of multiple inheritance. Mixins enhance code reuse and flexibility by allowing the composition of behavior from different objects.
When overriding a method in a subclass, use super.methodName() to call the original method from the _______ class.
- child
- parent
- subclass
- overridden
When overriding a method in a subclass, use super.methodName() to call the original method from the parent class. This allows the subclass to extend or modify the behavior of the parent method while still utilizing its functionality.
A const declaration ensures that the variable's __________ cannot be reassigned.
- type
- value
- identity
- scope
The correct option is 'value'. When a variable is declared with 'const' in JavaScript, its value cannot be reassigned. However, it's important to note that the const declaration does not make the variable itself immutable; it only ensures that the binding of the variable to a value remains constant.
Iterators enable lazy evaluation, allowing elements to be processed one at a time, as opposed to ________ evaluation.
- synchronous
- asynchronous
- parallel
- concurrent
Iterators in JavaScript enable lazy evaluation, meaning elements are processed one at a time on demand, in contrast to synchronous evaluation, where all elements are processed at once. This supports more efficient resource utilization.
Can a Symbol be automatically converted to a string when concatenated with a string?
- Yes, Symbols are automatically converted to strings
- No, attempting to concatenate a Symbol with a string will result in an error
- Only if the Symbol has an associated description
- Symbols cannot be concatenated with strings
No, a Symbol cannot be automatically converted to a string when concatenated with a string. Attempting to do so will not result in an error but will create a new string that includes the Symbol's description, if available, or the string representation of the Symbol.
To prevent modifications to an object’s prototype, the _________ method can be used to seal the prototype.
- Freeze
- Seal
- PreventExtensions
- Protect
The seal method in JavaScript can be used to prevent any further addition or deletion of properties on an object, including its prototype. This ensures that the prototype remains fixed and cannot be modified.