If you’ve ever tried to convert an Observable into a Signal using the toSignal() function, you might have encountered the following error NG0203: toSignal() can only be used within an injection context:
data:image/s3,"s3://crabby-images/89325/893257fc9c79ec3f99e73165f47a7e3355e42650" alt=""
This happens when you create an Observable outside of an injection context, which can happen if you want to download data when the user clicks on a button, for instance:
data:image/s3,"s3://crabby-images/d40b6/d40b6fb1bab8ae34722d8a638f4f23bbb29ea57e" alt=""
Can we make this work? Absolutely! The key is to access our injector and store it in a variable so we can pass it as a parameter to toSignal()
. How to do that?
Interestingly enough, we can access our injector by… injecting it into our component:
data:image/s3,"s3://crabby-images/99b58/99b58f2973441ec5db945da8f984b5d1a23791a3" alt=""
Then, we pass it as an option to the toSignal()
function:
data:image/s3,"s3://crabby-images/f3f2e/f3f2ef043666a40ffae78fde3e5884fd7921cab9" alt=""
And that’s it, problem solved! You can see the full code example on Stackblitz.