-
Notifications
You must be signed in to change notification settings - Fork 12.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
export access modifiers #41316
Comments
I like this approach! I think it would solve the most common use cases enumerated in #35554, #5228, #321, etc - that of needing a level between "public" and "private" (other than "protected" which is class-specific) to provide access to internals in a controlled way for the purpose of unit testing or to classes which do not extend the class itself. Currently, there is no "protected" equivalent for modules, so people use kludges like prefixing an underscore to the name to indicate that it's "internal" and shouldn't be used outside of that file and its unit tests. Having an official way to do this which is supported in the language would be outstanding. For example, the file export function Diagram(props: DiagramProps) {
return <>
<_Header>My Floorplan</_Header>
{props.rooms.map((r) => <_Room path={r.path}>{r.name}</_Room>)}
<_Legend />
</>;
}
export function _Header(props: HeaderProps) { ... }
export function _Room(props: HeaderProps) { ... }
export function _Legend() { ... } would become: export function Diagram(props: DiagramProps) {
return <>
<Header>My Floorplan</Header>
{props.rooms.map((r) => <Room path={r.path}>{r.name}</Room>)}
<Legend />
</>;
}
private export function Header(props: HeaderProps) { ... }
private function Room(props: HeaderProps) { ... }
private function Legend() { ... } This would allow |
Another approach to solve this issue would be Conditional Compilation - #3538 (comment) - but that's been sitting open for 6 years without any real movement on it... |
May I propose some clearer (IMHO) keywords:
We might also have something like:
The We might even have All of these could be useful when we need to make the visibility of the member more limited compared to the visibility of the class. |
I also upvoted for this feature. I'm annoyed by the fact that libraries use folder index files and when you're importing types, it may be confusing which path to import them from. And other developers may import the same thing from a different path which leads to unclean code. I would suggest another modifier:
All components could have public hidden exports of the components themselves and |
There's another issue #41425 discussing the same problem. |
FWIW, it seems like Microsoft has also run into this problem, and has made their own solution using "packlets". I agree that it'd be nice to have something like this be more standard. However, I do wonder whether it's something that should be developed in concert with other players in the JS ecosystem, rather than just addressing it in TS only through custom syntax. |
Love this idea, might be cool if you could use a |
Search Terms
export access modifiers public protected private
Related: #321
Suggestion
Allow adding
public
,protected
andprivate
access modifiers to export statements. This would limit where the data can be imported from.Access Modifiers
private
Other file in the same directory scope have access to the export.
protected
Other file in the same directory scope or a nested scope have access to the export.
public
(default)Current behavior - Can be access from anywhere.
Use Cases
Most useful for large projects - allows modules to limit where things they expose are used.
Examples
Given the following director structure:
Note: If using
import * as X from ...
,X
's type simply wouldn't include things it doesn't have access to.Checklist
My suggestion meets these guidelines:
The text was updated successfully, but these errors were encountered: