Not sure if this is considered best practice or if you should even do this but I have a small block of Javascript and I want to know if you can declare a variable, display that variable and then reassign it and display it again? Syntactically this seems correct but I would assume that this is not best practice and should be avoided?
Note: I did not write this block I just want to know if it’s ok or if I should change it and use 2 variables code below:
var u1 = 'something';
if (u1.indexOf('Accept') > 0)
{
var URL = 'some URL';
document.writeln(URL);
URL = 'another URL';
document.writeln(URL);
}
Thanks in advance.
EDIT:Thanks for the answers, thought it was a bit daft. :/
Yes you can
You can change variable’s value as many times as you need to. Variables are quite often reused so we save memory resources. Not in the way you’ve used them (because that’s an example that would be better off providing constant strings directly when calling functions) but think of an everyday example where we don’t even think of multiple variable value assignments. A
forloop:In this loop variable
igets assigned a new value 101 times. This is a rather obvious example, where we don’t think of this at all, but other than that, we could have a set of loops and reuse the same variable more explicitly and assign it a value lots of times like:This may be a much better example of explicit variable reusability where its value gets changed lots of times and for different purposes.
Variable naming
Variable reuse is sometimes unwanted/undesired. And that’s when we have a meaningful variable name like
isUserLoggedIn. It’s hard to reuse such variable for other purposes because it would make code unmaintainable.Variables that are usually reused may hence be iterators (ie.
i) or generally named variables without too much meaning. Or variables with more universal name (ie.finished) which can be reused in different contexts that can be associated with such variable name.Asynchronous code
There are certain situations where you may have problems even though looking at code may seem perfectly fine. And that’s when you use async functions which is frequently the case when using Ajax calls or time-deferred calls (ie.
setTimeout). Consider the following code:This code has a bug, because important code won’t be executed. Ever! This is quite a frequent misconception by unsavvy developers not understanding asynchronism.