this post was submitted on 24 Sep 2023
214 points (93.1% liked)

Programmer Humor

32380 readers
1039 users here now

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

founded 5 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 57 points 1 year ago (3 children)

If your code is that deeply nested, surely something has gone horribly wrong, yes?

[–] [email protected] 14 points 1 year ago (1 children)

Problem is that Js kind of encourages this being single threaded and using callbacks for anything blocking. To be fair, the new async syntax sugar helps in modern Js, but nesting a bunch of callbacks or promises was basically the way you did stuff for the longest time.

[–] [email protected] 15 points 1 year ago (1 children)

Yes and no. Any programming language encourages nesting as in the end the computer does nest your code. So it is only normal and predictable that languages would reflect that. BUT! Nest logic can often be inverted and by doing so, reduce how much nesting you need to do.

If (data is not null) {
    If (data has field x) {
         Return data x
    } else return null
} else return null

Can be

If (data is null) return null
If (data hasn't field x) return null
Return data x
[–] [email protected] 1 points 1 year ago (1 children)

I'm not arguing that avoiding deep nesting is a good idea, or that techniques foe doing that don't exist. I'm just pointing out that Js style programming naturally leads you to nesting things because of the nature of callbacks. Notice how your example isn't using callbacks.

[–] [email protected] 5 points 1 year ago (1 children)

Yeah and you can void nesting there just as easily and you have the same issues in any other programming language. You just need to create functions. Also JavaScript is not single threaded... you only have access to the dom on one thread, for obvious reasons.

Please explain to me how you do e.g. file downloads without a callback in your favorite language. If you solution involves having the main thread being stuck in a while loop, I am not sure if your complain about nested code can be taken seriously.

[–] [email protected] 10 points 1 year ago

Code aesthetic: If your code looks like a triangle, you're seriously doing something wrong.

[–] [email protected] 5 points 1 year ago (1 children)

I prefer a bunch of

if (fucked_up) {return(error_code);}

for checking common errors.

[–] [email protected] 2 points 1 year ago

Yup, never nest.

All the conditions should be checked and returned if they failed as you go through the function with the successful response being the last line.