Skip to content
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

Clarify useRef hook usages #412

Merged
merged 3 commits into from
May 3, 2021
Merged

Conversation

thien-do
Copy link
Contributor

@thien-do thien-do commented May 1, 2021

This is my suggestion follow a comment in #388 .

The problem with the current guide is that most newcomers will use the null! approach, which could cause hidden bug in practice, when the developer forget to assign the ref or conditionally render the ref-ed element. I saw this a lot, because this guide is the official reading recommendation in my company, and I keep seeing that bug 😅

My proposal is to not bypassing TypeScript, but let TypeScript does its job, by correctly tell it whether we need a RefObject and MutableRefObject. This also follows React's official guides, where there are 2 corresponding use cases (DOM access and mutable variable)

Thanks for contributing!

  • If you are making a significant PR, please make sure there is an open issue first
  • If you're just fixing typos or adding small notes, a brief explanation of why you'd like to add it would be nice :)

If you are contributing to README.md, DON'T. README.md is auto-generated. Please just make edits to the source inside of /docs/basic. Sorry, we get that it is a slight pain.

This is my suggestion follow a [comment](typescript-cheatsheets#388 (comment)) in typescript-cheatsheets#388 .

The problem with the current guide is that most newcomers will use the `null!` approach, which could cause hidden bug in practice, when the developer forget to assign the ref or conditionally render the ref-ed element. I saw this a lot, because this guide is the official reading recommendation in my company, and I keep seeing that bug.

My proposal is to not bypassing TypeScript, but let TypeScript does its job, by correctly tell it whether we need a RefObject and MutableRefObject. This also follows React's official guides, where there are 2 corresponding use cases (DOM access and mutable variable)
@thien-do
Copy link
Contributor Author

thien-do commented May 3, 2021

Hi @sw-yx ! Just wanted to say thank you for your commits. Your updates are so good. You're great at documenting stuffs.

@swyxio
Copy link
Collaborator

swyxio commented May 3, 2021

hahah too kind. thank you for contributing and hope you feel welcome to add more! this is a community effort.

@swyxio swyxio merged commit 09b10d4 into typescript-cheatsheets:main May 3, 2021
stepanenko added a commit to stepanenko/react-ts-best-practices that referenced this pull request May 9, 2021
* Updated README on 2021-04-02T14:21:23.928Z

* Fix missing parenthesis in troubleshooting types code example (typescript-cheatsheets#399)

Co-authored-by: swyx <shawnthe1@gmail.com>

* format

* minor improvements to "adding non-standard attributes" (typescript-cheatsheets#400)

* Added event types and their descriptions (typescript-cheatsheets#402)

* Added form types and their descriptions

I was looking for a complete list of form types and couldn't find any anywhere.
I went through the source code and extracted these with adding some description to them, either using MDN's description or some other website explanation.

* Apply suggestions from code review

Co-authored-by: swyx <shawnthe1@gmail.com>

* fix: Remove incorrect usage of "widening" (typescript-cheatsheets#405)

Using an intersection type here is actually narrowing the type, but the intent here seems to be to introduce type assertions, not talk about the difference between wider and narrower types.

* add type assertion for useState thanks @priscilaandreani

closes typescript-cheatsheets#403

* format

* Fixed typo (typescript-cheatsheets#406)

Fixed an issue where a paragraph described three different options as two.

* Add rollpkg as an option for creating libraries (typescript-cheatsheets#407)

* useLocalStorage Type detection bug (typescript-cheatsheets#409)

in my vs code it detects that the type of soredValue is (T | (value: T | ((val: T) => T)) => void)
but it must be just (T)
so it throws error 
with this change it solved.

* Updated README on 2021-04-25T20:13:23.562Z

* Clarify useRef hook usages (typescript-cheatsheets#412)

Co-authored-by: swyx <shawnthe1@gmail.com>

* Update index.md

* Update from-flow.md

* docs: throw when ref.current is null (typescript-cheatsheets#413)

* Update types.md

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Denis LE <ledenis@users.noreply.github.com>
Co-authored-by: swyx <shawnthe1@gmail.com>
Co-authored-by: Sebastian Silbermann <silbermann.sebastian@gmail.com>
Co-authored-by: Lars <32460418+advename@users.noreply.github.com>
Co-authored-by: Gerrit Birkeland <gerrit@gerritbirkeland.com>
Co-authored-by: Christopher Kumm <40023417+ChrisCrossCrash@users.noreply.github.com>
Co-authored-by: Rafael Pedicini <rafael@rafgraph.dev>
Co-authored-by: Mandy YP <63463742+mmdHasan-yazdanPanah@users.noreply.github.com>
Co-authored-by: Thien Do <hello@thien.do>
Co-authored-by: Christina Grannas <christina.grannas@gmail.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants