-
Notifications
You must be signed in to change notification settings - Fork 12.9k
Closed
Labels
CommittedThe team has roadmapped this issueThe team has roadmapped this issueFixedA PR has been merged for this issueA PR has been merged for this issueSuggestionAn idea for TypeScriptAn idea for TypeScript
Milestone
Description
It doesn't make much sense to forbid property access (o.unknown
) syntax on a type with a string index signature, but allow element access syntax (o['unknown']
).
Note that this should only apply to types with an explicit string index signature — element access is currently allowed on any type if you don't pass --noImplicitAny
, but this should not be true for property access.
Given
type Flags = {
aLongName: boolean;
anotherReallyLongOne: number;
someOtherOnes: boolean;
[other: string]: number | boolean;
}
Expected behavior:
function f(flags: Flags) {
flags.aLongName; // ok
flags.anUnknownName; // ok
flags.aLongname; // ok, but misspelled
flags['aLongName']; // ok
flags['anUnknownName']; // ok
flags['aLongname']; // ok, but misspelled
}
Actual behavior:
function f(flags: Flags) {
flags.aLongName; // ok
flags.anUnknownName; // error, unknown
flags.aLongname; // error, misspelled
flags['aLongName']; // ok
flags['anUnknownName']; // ok
flags['aLongname']; // ok, but misspelled
}
stevehansen, blakeembrey, e-cloud, bfricka, Spown and 13 morejeffreymorlan, timocov, ethanresnick and evil-shrikealuanhaddad, abenhamdine, mavericken, btraut and niieani
Metadata
Metadata
Assignees
Labels
CommittedThe team has roadmapped this issueThe team has roadmapped this issueFixedA PR has been merged for this issueA PR has been merged for this issueSuggestionAn idea for TypeScriptAn idea for TypeScript