If a fetch call fails in Chrome, then the only error details that I get back is
TypeError: Failed to fetch
How do I display an informative error message to the end user in this case?
Specifically:
Is it possible to get any details about why fetch failed?
For example, if the server crashed, Chrome DevTools might log a console message of net:ERR_EMPTY_RESPONSE, but there appears to be no way to access this from JavaScript.
As far as I can tell, the answer is no; I assume this is for security reasons, to avoid letting malicious JS find out which sites are and aren't accessible by inspecting error messages.
Is it possible to distinguish fetch errors from other TypeErrors?
If I can't get error details, I'd like to at least replace the horribly vague "Failed to fetch" with an informative "Failed to access the web site; please try again later" message, and I'd like to do this without any risk of displaying that message for other TypeErrors.
The only solution I've found here is to check the actual message to see if it's "Failed to fetch". This is obviously browser-specific; it works in Chrome, it seems like it will work in any user language of Chrome, and other browsers would need their own testing and handling.
TypeErrorseems like...really the wrong error type. Strange..catchdoesn't work for you?.catchworks, but I'd like to get error details if possible (my first question), and to avoid incorrectly catching otherTypeErrors as fetch errors, I feel like I either have to put the.catchvery close tofetch(so no other errors can occur, thus losing flexibility in how I structure my promises) or rely on browser-specific behavior like the text of the fetchmessage(my second question)..catchstop the output to console (I take it that's where this error is showing)TypeError: Failed to fetchmessage is all you get in the.catchso you'll have to do some fancy footwork to change that to a meaningful message - the.catchcan be at the end of the chain, doesn't matter