JavaScript Interview Questions
  • JavaScript Interview Questions
  • Contact
  • Introduction
  • Question 1
  • Question 2
  • Question 3
  • Question 4
  • Question 5
  • Question 6
  • Question 7
  • Question 8
  • Question 9
  • Question 10
  • Question 11
  • Question 12
  • Question 13
  • Question 14
  • Question 15
  • Question 16
  • Question 17
  • Question 18
  • Question 19
  • Question 20
  • Question 21
  • Question 22
  • Question 23
  • Question 24
  • Question 25
  • Question 26
  • Question 27
  • Question 28
  • Question 29
  • Question 30
  • Question 31
  • Question 32
  • Question 33
  • Question 34
  • Question 35
  • Question 36
  • Question 37
  • Question 38
  • Question 39
  • Question 40
  • Question 41
  • Question 42
  • Question 43
  • Question 44
  • Question 45
  • Question 46
  • Question 47
  • Question 48
  • Question 49
  • Question 50
  • Question 51
  • Question 52
  • Question 53
  • Question 54
  • Question 55
  • Question 56
  • Question 57
  • Question 58
  • Question 59
  • Question 60
  • Question 61
  • Question 62
  • Question 63
  • Question 64
  • Question 65
  • Question 66
  • Question 67
  • Question 68
  • Question 69
  • Question 70
  • Question 71
  • Question 72
  • Question 73
  • Question 74
  • Question 75
  • Question 76
  • Question 77
  • Question 78
  • Question 79
  • Question 80
  • Question 81
  • Question 82
  • Question 83
  • Question 84
  • Question 85
  • Question 86
  • Question 87
  • Question 88
  • Question 89
  • Question 90
  • Question 91
  • Question 92
  • Question 93
  • Question 94
  • Question 95
  • Question 96
  • Question 97
  • Question 98
  • Question 99
  • Question 100
  • Epilogue
Powered by GitBook
On this page
  • Question
  • Answer

Question 33

Question

How would you create a custom symbol registry to prevent collision of Symbol values?

Answer

While the Symbol() function generates unique symbols in most cases, creating a custom symbol registry can be beneficial for specific scenarios where you need finer control and predictability over symbol assignments.

Here's how you could implement a basic custom symbol registry:

class SymbolRegistry {
  constructor() {
    this.symbols = {}; // Map to store registered symbols
  }

  register(name) {
    if (!this.hasSymbol(name)) {
      const symbol = Symbol(name); 
      this.symbols[name] = symbol;
      return symbol;
    } else {
      console.warn(`Symbol '${name}' already exists in the registry`);
      return this.symbols[name];
    }
  }

  hasSymbol(name) {
    return !!this.symbols[name];
  }

  getSymbol(name) {
    return this.symbols[name];
  }
}

// Usage Example:
const registry = new SymbolRegistry();

const mySymbol1 = registry.register('data');
const mySymbol2 = registry.register('view'); 

console.log(mySymbol1); // Output unique symbol for 'data'
console.log(registry.getSymbol('data')); // Accessing the registered symbol

Explanation:

  1. SymbolRegistry Class: We create a class to manage our symbols. It has a symbols map to store registered symbols using names as keys.

  2. register(name) Method:

    • Checks if a symbol with the given name already exists in the registry.

    • If not, it generates a new symbol using Symbol(name) and stores it in the symbols map, returning the newly created symbol.

  3. hasSymbol(name) Method:

    • Checks if a symbol with the given name is present in the registry.

  4. getSymbol(name) Method:

    • Returns the previously registered symbol associated with the given name.

Benefits of Using a Symbol Registry:

  • Controlled Namespace: Ensures that symbols used within your application are unique and avoid collisions, even across different modules or components.

  • Readability and Maintainability: Makes it easier to understand which symbols represent specific concepts in your code.

  • Testability: You can easily mock or stub symbol values during testing.

PreviousQuestion 32NextQuestion 34

Last updated 9 months ago