private fields in nested classes should have separate types?Β #60882
Open
Description
π Search Terms
typescript private field nested class
β Viability Checklist
- This wouldn't be a breaking change in existing TypeScript/JavaScript code
- This wouldn't change the runtime behavior of existing JavaScript code
- This could be implemented without emitting different JS based on the types of the expressions
- This isn't a runtime feature (e.g. library functionality, non-ECMAScript syntax with JavaScript output, new syntax sugar for JS, etc.)
- This isn't a request to add a new utility type: https://github.com/microsoft/TypeScript/wiki/No-New-Utility-Types
- This feature would agree with the rest of our Design Goals: https://github.com/Microsoft/TypeScript/wiki/TypeScript-Design-Goals
β Suggestion
Private fields of a wrapper class are similar to symbols: perhaps the nested classes could have their own types for the fields based on the value they initialize in their constructor:
π Motivating Example
Plain JS:
class Friends {
#priv
Foo = class Foo extends Friends {
constructor() {
super()
this.#priv = 456 // <----------- number
}
fooMethod() {
console.log(this.#priv)
}
}
Bar = class Bar extends this.Foo {
constructor() {
super()
this.#priv = "789" // <-------------- string
}
barMethod() {
console.log(this.#priv)
}
}
}
const {Foo, Bar} = new Friends()
const f = new Foo()
const b = new Bar()
f.fooMethod() // logs "456"
b.barMethod() // logs "789"
π» Use Cases
Allows having a "private" key to use on multiple classes, but each class could have a different type of value.