Synchronous غلطیں try/catch/finally استعمال کرتی ہیں، اور آپ کو throw Error اشیاء (strings نہیں) کرنی چاہیے تاکہ آپ کو stack trace مل سکے۔
js
{
data = .(input);
} (err) {
(err ) (err);
err;
} {
();
}
Synchronous غلطیں try/catch/finally استعمال کرتی ہیں، اور آپ کو throw Error اشیاء (strings نہیں) کرنی چاہیے تاکہ آپ کو stack trace مل سکے۔
{
data = .(input);
} (err) {
(err ) (err);
err;
} {
();
}
// async/await → wrap awaits in try/catch
async function load() {
try {
return await fetch(url).then(r => r.json());
} catch (err) { showError(err); }
}
// promises → use .catch
fetch(url).then(use).catch(showError);
try {
setTimeout(() => { throw new Error("boom"); }, 0); // ❌ NOT caught
} catch (e) { /* never runs — the throw happens later, outside this stack */ }
setTimeout callback ایک بعد میں آنے والے tick پر چلتا ہے، اس لیے اردگرد والا try پہلے سے ختم ہو چکا ہے۔ غلطی کو callback کے اندر سنبھالیں۔
window.addEventListener("unhandledrejection", e => log(e.reason)); // browser
process.on("unhandledRejection", err => log(err)); // Node
instanceof چیکس کے لیے Error (یا custom subclasses) throw کریں۔catch کریں؛ غیر متوقع غلطیوں کو بلبلہ کرنے دیں۔catch (e) {})۔ ہمیشہ log کریں یا rethrow کریں۔