Web Worker

Loading "Web Worker"
Warning, this one's really cool, but kinda tricky... Also, the intent isn't necessarily for you to learn about web workers, but just to expose you to a good use case for them. You can get started learning about web workers in Speed up your app with web workers.
πŸ‘¨β€πŸ’Ό It's awesome that we reduced how often we have to call searchCities. Unfortunately, on low-powered devices, searchCities is still quite slow when it actually does need to run and we'd like to speed it up. So I was thinking that we need to ditch match-sorter in favor of a simple string includes because the experience is not fast enough (even though match-sorter does provide a much superior UX).
But no! We must have the better UX! There may be ways to optimize match-sorter itself, but let's try throwing this all into a web worker instead...
This change is going to take two steps. So when we're finished with this bit, we actually won't see any improvement until we take advantage of it in the next step.
πŸ§β€β™‚οΈ To avoid distrupting our existing App component, I have copied into and update the import in . Feel free to check it out.
πŸ‘¨β€πŸ’Ό Thanks Kellie! Now you're ready to make changes in and for this exercise.
Oh, and when you're finished with that, then go into and add an import for ./cities/index.ts just so you can see the web worker get loaded into our sources tab of the DevTools like this:
Sources tab in devtools showing another thread called filter-cities.worker.ts
πŸ¦‰ We'll be using a library called comlink to manage communication with this web worker and have some nice type safety. You may find it useful to view the docs a bit for that project before proceeding.
We'll also be taking advantage of Vite's web workers feature. Those docs would also be useful to peruse just a bit.
Login to get access to the exclusive discord channel.
  • General
    Not able to launch editor
    Lenssen:
    I'm stuck here and not able to launch the edior
    1 Β· 14 hours ago
  • General
    βš›οΈFundamentals
    Error boundary good practice
    Lloren πŸš€:
    I have always wondered if the error boundary is there a limit of error boundary that you can impleme...
    • βœ…1
    1 Β· a day ago
  • General
    Script to save playground folder
    larissapissurno πŸš€:
    Hi all, I personally like to take notes on the playground files, so in order to not lose this notes ...
    1 Β· 3 days ago
  • General
    Received this error when running the setup script for React Fundamentals
    ChrisP πŸš€:
    Hey guys, I am completely blocked at the moment. When I clone and run the setup for react fundamenta...
    • βœ…1
    2 Β· 6 days ago
  • General
    Unexpected server error (workshop-app does not load onboarding step)
    Matias 🌌 πŸš€:
    Hey! πŸ‘‹ I installed the free workshop "Build React Hooks" last week with no issues. Yesterday, whe...
    • βœ…1
    3 Β· 8 days ago
  • General
    Eye opening moment in 05/06 (β€žsatisfiesβ€œ operator of typescript)
    Chrigi πŸš€:
    Up until today I was not aware that having the type annotation on a variable is actually a type-cast...
    • πŸ™Œ2
    • βœ…1
    2 Β· 9 days ago
  • General
    Launch editor error: Could not open 'index.html' from:'playground' in the editor.
    Japhet πŸš€ πŸ†:
    I'm encountering an issue when trying to open a link from the file list. The error message I receive...
    • βœ…1
    15 Β· 5 days ago
  • General
    Failed to fetch dynamically imported module...
    FacuPerezM:
    I am getting this error out of nowhere, in the 'test' tab inside the Workshop app. ``` Failed to f...
    • βœ…1
    3 Β· 13 days ago
  • General
    Runninng Learning app on iPad?
    marcus_polonus πŸš€:
    Hi all, Did anyone managed to setup learning app on iPad? I tried to use codesandbox, but when I am...
    0 Β· 13 days ago
  • General
    Clicking an exercise file launch VIM instead of VS Code
    DBattou πŸš€:
    I started going through the workshops, everything is setup and working fine except for opening a fil...
    • βœ…1
    2 Β· 17 days ago
  • General
    Epicshop not saving the video resolution
    Toni πŸš€ 🌌:
    Playback speed and caption settings are saved, but the video resolution always defaults to auto. Is ...
    • βœ…1
    7 Β· 18 days ago
  • General
    Launch editor error: spawn code ENOENT
    Andrew Elans 🌌 πŸš€:
    Clicking index.html gives this error in VS Code. Both from Chrome and Safari. Anyone?
    • βœ…2
    4 Β· a month ago
  • General
    Welcome to EpicReact.dev! Say Hello πŸ‘‹
    Kent C. Dodds β—† πŸš€πŸ†πŸŒŒ:
    Welcome to the first of many posts in the EpicReact.dev channel! Take a moment to introduce yourself...
    • πŸš€5
    40 Β· 3 days ago