Monday, 26 February 2018

Advanced JavaScript: Why is this function wrapped in parentheses?





Possible Duplicate:
What is the (function() { } )() construct in JavaScript?







I came across this bit of JavaScript code, but I have no idea what to make out of it. Why do I get "1" when I run this code? What is this strange little appendix of (1) and why is the function wrapped in parentheses?



(function(x){
delete x;
return x;
})(1);

Answer




There are a few things going on here. First is the immediately invoked function expression (IIFE) pattern:



(function() {
// Some code
})();


This provides a way to execute some JavaScript code in its own scope. It's usually used so that any variables created within the function won't affect the global scope. You could use this instead:



function foo() {

// Some code
}
foo();


But this requires giving a name to the function, which is not always necessary. Using a named function also means at some future point the function could be called again which might not be desirable. By using an anonymous function in this manner you ensure it's only executed once.



This syntax is invalid:



function() {

// Some code
}();


Because you have to wrap the function in parentheses in order to make it parse as an expression. More information is here: http://benalman.com/news/2010/11/immediately-invoked-function-expression/



So to recap quickly on the IIFE pattern:



(function() {
// Some code

})();


Allows 'some code' to be executed immediately, as if it was just written inline, but also within its own scope so as not to affect the global namespace (and thus potentially interfere with or be interfered with by, other scripts).



You can pass arguments to your function just as you would a normal function, for example,



(function(x) {
// Some code
})(1);



So we're passing the value '1' as the first argument to the function, which receives it as a locally scoped variable, named x.



Secondly, you have the guts of the function code itself:



delete x;
return x;



The delete operator will remove properties from objects. It doesn't delete variables. So;



var foo = {'bar':4, 'baz':5};
delete foo.bar;
console.log(foo);


Results in this being logged:



{'baz':5}



Whereas,



var foo = 4;
delete foo;
console.log(foo);


will log the value 4, because foo is a variable not a property and so it can't be deleted.




Many people assume that delete can delete variables, because of the way autoglobals work. If you assign to a variable without declaring it first, it will not actually become a variable, but a property on the global object:



bar = 4; // Note the lack of 'var'. Bad practice! Don't ever do this!
delete bar;
console.log(bar); // Error - bar is not defined.


This time the delete works, because you're not deleting a variable, but a property on the global object. In effect, the previous snippet is equivalent to this:




window.bar = 4;
delete window.bar;
console.log(window.bar);


And now you can see how it's analogous to the foo object example and not the foo variable example.


No comments:

Post a Comment

casting - Why wasn't Tobey Maguire in The Amazing Spider-Man? - Movies & TV

In the Spider-Man franchise, Tobey Maguire is an outstanding performer as a Spider-Man and also reprised his role in the sequels Spider-Man...