var functionName = function() {} vs function functionName() {}












6246














I've recently started maintaining someone else's JavaScript code. I'm fixing bugs, adding features, and also trying to tidy up the code and make it more consistent.



The previous developer uses two ways of declaring functions and I can't work out if there is a reason behind it or not.



The two ways are:



var functionOne = function() {
// Some code
};




function functionTwo() {
// Some code
}


What are the reasons for using these two different methods and what are the pros and cons of each? Is there anything that can be done with one method that can't be done with the other?










share|improve this question




















  • 188




    permadi.com/tutorial/jsFunc/index.html is very good page about javascript functions
    – uzay95
    Apr 9 '10 at 11:51






  • 63




    Related is this excellent article on Named Function Expressions.
    – Phrogz
    Apr 21 '11 at 21:30






  • 11




    @CMS references this article: kangax.github.com/nfe/#expr-vs-decl
    – Upperstage
    Aug 3 '11 at 14:18






  • 95




    There are two things you need to be aware of: #1 In JavaScript, declarations are hoisted. Meaning that var a = 1; var b = 2; becomes var a; var b; a = 1; b = 2. So when you declare functionOne, it gets declared but its value isn't set immediately. Whereas since functionTwo is just a declaration, it gets put at the top of the scope. #2 functionTwo lets you access the name property and that helps a lot when trying to debug something.
    – xavierm02
    Aug 21 '12 at 16:20








  • 58




    Oh and btw, the correct syntax is with a ";" after the assignation and without after the declaration. E.g. function f(){} vs var f = function(){};.
    – xavierm02
    Aug 21 '12 at 16:27
















6246














I've recently started maintaining someone else's JavaScript code. I'm fixing bugs, adding features, and also trying to tidy up the code and make it more consistent.



The previous developer uses two ways of declaring functions and I can't work out if there is a reason behind it or not.



The two ways are:



var functionOne = function() {
// Some code
};




function functionTwo() {
// Some code
}


What are the reasons for using these two different methods and what are the pros and cons of each? Is there anything that can be done with one method that can't be done with the other?










share|improve this question




















  • 188




    permadi.com/tutorial/jsFunc/index.html is very good page about javascript functions
    – uzay95
    Apr 9 '10 at 11:51






  • 63




    Related is this excellent article on Named Function Expressions.
    – Phrogz
    Apr 21 '11 at 21:30






  • 11




    @CMS references this article: kangax.github.com/nfe/#expr-vs-decl
    – Upperstage
    Aug 3 '11 at 14:18






  • 95




    There are two things you need to be aware of: #1 In JavaScript, declarations are hoisted. Meaning that var a = 1; var b = 2; becomes var a; var b; a = 1; b = 2. So when you declare functionOne, it gets declared but its value isn't set immediately. Whereas since functionTwo is just a declaration, it gets put at the top of the scope. #2 functionTwo lets you access the name property and that helps a lot when trying to debug something.
    – xavierm02
    Aug 21 '12 at 16:20








  • 58




    Oh and btw, the correct syntax is with a ";" after the assignation and without after the declaration. E.g. function f(){} vs var f = function(){};.
    – xavierm02
    Aug 21 '12 at 16:27














6246












6246








6246


2350





I've recently started maintaining someone else's JavaScript code. I'm fixing bugs, adding features, and also trying to tidy up the code and make it more consistent.



The previous developer uses two ways of declaring functions and I can't work out if there is a reason behind it or not.



The two ways are:



var functionOne = function() {
// Some code
};




function functionTwo() {
// Some code
}


What are the reasons for using these two different methods and what are the pros and cons of each? Is there anything that can be done with one method that can't be done with the other?










share|improve this question















I've recently started maintaining someone else's JavaScript code. I'm fixing bugs, adding features, and also trying to tidy up the code and make it more consistent.



The previous developer uses two ways of declaring functions and I can't work out if there is a reason behind it or not.



The two ways are:



var functionOne = function() {
// Some code
};




function functionTwo() {
// Some code
}


What are the reasons for using these two different methods and what are the pros and cons of each? Is there anything that can be done with one method that can't be done with the other?







javascript function syntax idioms






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Sep 13 at 10:25









Luca Kiebel

7,29841431




7,29841431










asked Dec 3 '08 at 11:31









Richard Garside

40.2k86173




40.2k86173








  • 188




    permadi.com/tutorial/jsFunc/index.html is very good page about javascript functions
    – uzay95
    Apr 9 '10 at 11:51






  • 63




    Related is this excellent article on Named Function Expressions.
    – Phrogz
    Apr 21 '11 at 21:30






  • 11




    @CMS references this article: kangax.github.com/nfe/#expr-vs-decl
    – Upperstage
    Aug 3 '11 at 14:18






  • 95




    There are two things you need to be aware of: #1 In JavaScript, declarations are hoisted. Meaning that var a = 1; var b = 2; becomes var a; var b; a = 1; b = 2. So when you declare functionOne, it gets declared but its value isn't set immediately. Whereas since functionTwo is just a declaration, it gets put at the top of the scope. #2 functionTwo lets you access the name property and that helps a lot when trying to debug something.
    – xavierm02
    Aug 21 '12 at 16:20








  • 58




    Oh and btw, the correct syntax is with a ";" after the assignation and without after the declaration. E.g. function f(){} vs var f = function(){};.
    – xavierm02
    Aug 21 '12 at 16:27














  • 188




    permadi.com/tutorial/jsFunc/index.html is very good page about javascript functions
    – uzay95
    Apr 9 '10 at 11:51






  • 63




    Related is this excellent article on Named Function Expressions.
    – Phrogz
    Apr 21 '11 at 21:30






  • 11




    @CMS references this article: kangax.github.com/nfe/#expr-vs-decl
    – Upperstage
    Aug 3 '11 at 14:18






  • 95




    There are two things you need to be aware of: #1 In JavaScript, declarations are hoisted. Meaning that var a = 1; var b = 2; becomes var a; var b; a = 1; b = 2. So when you declare functionOne, it gets declared but its value isn't set immediately. Whereas since functionTwo is just a declaration, it gets put at the top of the scope. #2 functionTwo lets you access the name property and that helps a lot when trying to debug something.
    – xavierm02
    Aug 21 '12 at 16:20








  • 58




    Oh and btw, the correct syntax is with a ";" after the assignation and without after the declaration. E.g. function f(){} vs var f = function(){};.
    – xavierm02
    Aug 21 '12 at 16:27








188




188




permadi.com/tutorial/jsFunc/index.html is very good page about javascript functions
– uzay95
Apr 9 '10 at 11:51




permadi.com/tutorial/jsFunc/index.html is very good page about javascript functions
– uzay95
Apr 9 '10 at 11:51




63




63




Related is this excellent article on Named Function Expressions.
– Phrogz
Apr 21 '11 at 21:30




Related is this excellent article on Named Function Expressions.
– Phrogz
Apr 21 '11 at 21:30




11




11




@CMS references this article: kangax.github.com/nfe/#expr-vs-decl
– Upperstage
Aug 3 '11 at 14:18




@CMS references this article: kangax.github.com/nfe/#expr-vs-decl
– Upperstage
Aug 3 '11 at 14:18




95




95




There are two things you need to be aware of: #1 In JavaScript, declarations are hoisted. Meaning that var a = 1; var b = 2; becomes var a; var b; a = 1; b = 2. So when you declare functionOne, it gets declared but its value isn't set immediately. Whereas since functionTwo is just a declaration, it gets put at the top of the scope. #2 functionTwo lets you access the name property and that helps a lot when trying to debug something.
– xavierm02
Aug 21 '12 at 16:20






There are two things you need to be aware of: #1 In JavaScript, declarations are hoisted. Meaning that var a = 1; var b = 2; becomes var a; var b; a = 1; b = 2. So when you declare functionOne, it gets declared but its value isn't set immediately. Whereas since functionTwo is just a declaration, it gets put at the top of the scope. #2 functionTwo lets you access the name property and that helps a lot when trying to debug something.
– xavierm02
Aug 21 '12 at 16:20






58




58




Oh and btw, the correct syntax is with a ";" after the assignation and without after the declaration. E.g. function f(){} vs var f = function(){};.
– xavierm02
Aug 21 '12 at 16:27




Oh and btw, the correct syntax is with a ";" after the assignation and without after the declaration. E.g. function f(){} vs var f = function(){};.
– xavierm02
Aug 21 '12 at 16:27












35 Answers
35






active

oldest

votes













1 2
next












4640














The difference is that functionOne is a function expression and so only defined when that line is reached, whereas functionTwo is a function declaration and is defined as soon as its surrounding function or script is executed (due to hoisting).



For example, a function expression:






// TypeError: functionOne is not a function
functionOne();

var functionOne = function() {
console.log("Hello!");
};





And, a function declaration:






// Outputs: "Hello!"
functionTwo();

function functionTwo() {
console.log("Hello!");
}





This also means you can't conditionally define functions using function declarations:



if (test) {
// Error or misbehavior
function functionThree() { doSomething(); }
}


The above actually defines functionThree irrespective of test's value — unless use strict is in effect, in which case it simply raises an error.






share|improve this answer



















  • 578




    @Greg: By the way, the difference isn't only that they are parsed at different times. Essentially, your functionOne is merely a variable that has an anonymous function assigned to it, whereas functionTwo is actually a named function. Call .toString() on both to see the difference. This is significant in some cases where you want to get the name of a function programmatically.
    – Jason Bunting
    Aug 5 '11 at 21:18






  • 4




    @Jason Bunting.. not sure what you're getting at here, .toString() seems to return essentially the same value (the function definition) for both: cl.ly/2a2C2Y1r0J451o0q0B1B
    – Jon z
    Sep 9 '11 at 16:29








  • 122




    There are both different. The first one is a function expression the second one is a function declaration. You can read more on the topic here: javascriptweblog.wordpress.com/2010/07/06/…
    – Michal Kuklis
    Nov 14 '11 at 6:03






  • 124




    @Greg The part of your answer concerning parse time vs. run time is not correct. In JavaScript, function declarations are not defined during parse time, but during run time. The process goes like this: Source code is parsed -> JavaScript program is evaluated -> The global execution context is initialized -> declaration binding instantiation is performed. During this process the function declarations are instantiated (see step 5 of Chapter 10.5).
    – Šime Vidas
    Jan 4 '12 at 0:59






  • 98




    The terminology for this phenomenon is known as hoisting.
    – Colin Pear
    Jan 3 '13 at 7:22



















1839














First I want to correct Greg: function abc(){} is scoped too — the name abc is defined in the scope where this definition is encountered. Example:



function xyz(){
function abc(){};
// abc is defined here...
}
// ...but not here


Secondly, it is possible to combine both styles:



var xyz = function abc(){};


xyz is going to be defined as usual, abc is undefined in all browsers but Internet Explorer — do not rely on it being defined. But it will be defined inside its body:



var xyz = function abc(){
// xyz is visible here
// abc is visible here
}
// xyz is visible here
// abc is undefined here


If you want to alias functions on all browsers, use this kind of declaration:



function abc(){};
var xyz = abc;


In this case, both xyz and abc are aliases of the same object:



console.log(xyz === abc); // prints "true"


One compelling reason to use the combined style is the "name" attribute of function objects (not supported by Internet Explorer). Basically when you define a function like



function abc(){};
console.log(abc.name); // prints "abc"


its name is automatically assigned. But when you define it like



var abc = function(){};
console.log(abc.name); // prints ""


its name is empty — we created an anonymous function and assigned it to some variable.



Another good reason to use the combined style is to use a short internal name to refer to itself, while providing a long non-conflicting name for external users:



// Assume really.long.external.scoped is {}
really.long.external.scoped.name = function shortcut(n){
// Let it call itself recursively:
shortcut(n - 1);
// ...
// Let it pass itself as a callback:
someFunction(shortcut);
// ...
}


In the example above we can do the same with an external name, but it'll be too unwieldy (and slower).



(Another way to refer to itself is to use arguments.callee, which is still relatively long, and not supported in the strict mode.)



Deep down, JavaScript treats both statements differently. This is a function declaration:



function abc(){}


abc here is defined everywhere in the current scope:



// We can call it here
abc(); // Works

// Yet, it is defined down there.
function abc(){}

// We can call it again
abc(); // Works


Also, it hoisted through a return statement:



// We can call it here
abc(); // Works
return;
function abc(){}


This is a function expression:



var xyz = function(){};


xyz here is defined from the point of assignment:



// We can't call it here
xyz(); // UNDEFINED!!!

// Now it is defined
xyz = function(){}

// We can call it here
xyz(); // works


Function declaration vs. function expression is the real reason why there is a difference demonstrated by Greg.



Fun fact:



var xyz = function abc(){};
console.log(xyz.name); // Prints "abc"


Personally, I prefer the "function expression" declaration because this way I can control the visibility. When I define the function like



var abc = function(){};


I know that I defined the function locally. When I define the function like



abc = function(){};


I know that I defined it globally providing that I didn't define abc anywhere in the chain of scopes. This style of definition is resilient even when used inside eval(). While the definition



function abc(){};


depends on the context and may leave you guessing where it is actually defined, especially in the case of eval() — the answer is: It depends on the browser.






share|improve this answer



















  • 65




    I refer to RoBorg but he is nowhere to be found. Simple: RoBorg === Greg. That's how history can be rewritten in the age of internet. ;-)
    – Eugene Lazutkin
    Jul 26 '09 at 2:52






  • 10




    var xyz = function abc(){}; console.log(xyz === abc); All browsers I've tested (Safari 4, Firefox 3.5.5, Opera 10.10) gives me "Undefined variable: abc".
    – NVI
    Dec 3 '09 at 17:43






  • 6




    Overall I think this post does a good job of explaining the differences and the advantages of utilizing the function declaration. I'll agree to disagree as far as the benefits of utilizing function expression assignments to a variable especially since the "benefit" seems to be an advocation of declaring a global entity... and everyone knows that you shouldn't clutter the global namespace, right? ;-)
    – natlee75
    Oct 8 '13 at 16:30






  • 77




    imo a huge reason to use named function is because debuggers can use the name to help you make sense of your call stack or stack trace. it sucks when you look at the call stack and see "anonymous function" 10 levels deep...
    – goat
    Jan 26 '14 at 18:25






  • 2




    @Antimony A function declaration is not the same thing as a block. This should explain better: stackoverflow.com/questions/17409945/…
    – Cypher
    Mar 27 '14 at 23:25



















568





+200









Here's the rundown on the standard forms that create functions: (Originally written for another question, but adapted after being moved into the canonical question.)



Terms:





  • ES5: ECMAScript 5th edition, 2009


  • ES2015: ECMAScript 2015 (also known as "ES6")


The quick list:




  • Function Declaration


  • "Anonymous" function Expression (which despite the term, sometimes create functions with names)


  • Named function Expression


  • Accessor Function Initializer (ES5+)


  • Arrow Function Expression (ES2015+) (which, like anonymous function expressions, don't involve an explicit name, and yet can create functions with names)


  • Method Declaration in Object Initializer (ES2015+)


  • Constructor and Method Declarations in class (ES2015+)



Function Declaration



The first form is a function declaration, which looks like this:



function x() {
console.log('x');
}


A function declaration is a declaration; it's not a statement or expression. As such, you don't follow it with a ; (although doing so is harmless).



A function declaration is processed when execution enters the context in which it appears, before any step-by-step code is executed. The function it creates is given a proper name (x in the example above), and that name is put in the scope in which the declaration appears.



Because it's processed before any step-by-step code in the same context, you can do things like this:



x(); // Works even though it's above the declaration
function x() {
console.log('x');
}


Until ES2015, the spec didn't cover what a JavaScript engine should do if you put a function declaration inside a control structure like try, if, switch, while, etc., like this:



if (someCondition) {
function foo() { // <===== HERE THERE
} // <===== BE DRAGONS
}


And since they're processed before step-by-step code is run, it's tricky to know what to do when they're in a control structure.



Although doing this wasn't specified until ES2015, it was an allowable extension to support function declarations in blocks. Unfortunately (and inevitably), different engines did different things.



As of ES2015, the specification says what to do. In fact, it gives three separate things to do:




  1. If in loose mode not on a web browser, the JavaScript engine is supposed to do one thing

  2. If in loose mode on a web browser, the JavaScript engine is supposed to do something else

  3. If in strict mode (browser or not), the JavaScript engine is supposed to do yet another thing


The rules for the loose modes are tricky, but in strict mode, function declarations in blocks are easy: They're local to the block (they have block scope, which is also new in ES2015), and they're hoisted to the top of the block. So:



"use strict";
if (someCondition) {
foo(); // Works just fine
function foo() {
}
}
console.log(typeof foo); // "undefined" (`foo` is not in scope here
// because it's not in the same block)


"Anonymous" function Expression



The second common form is called an anonymous function expression:



var y = function () {
console.log('y');
};


Like all expressions, it's evaluated when it's reached in the step-by-step execution of the code.



In ES5, the function this creates has no name (it's anonymous). In ES2015, the function is assigned a name if possible by inferring it from context. In the example above, the name would be y. Something similar is done when the function is the value of a property initializer. (For details on when this happens and the rules, search for SetFunctionName in the the specification — it appears all over the place.)



Named function Expression



The third form is a named function expression ("NFE"):



var z = function w() {
console.log('zw')
};


The function this creates has a proper name (w in this case). Like all expressions, this is evaluated when it's reached in the step-by-step execution of the code. The name of the function is not added to the scope in which the expression appears; the name is in scope within the function itself:



var z = function w() {
console.log(typeof w); // "function"
};
console.log(typeof w); // "undefined"


Note that NFEs have frequently been a source of bugs for JavaScript implementations. IE8 and earlier, for instance, handle NFEs completely incorrectly, creating two different functions at two different times. Early versions of Safari had issues as well. The good news is that current versions of browsers (IE9 and up, current Safari) don't have those issues any more. (But as of this writing, sadly, IE8 remains in widespread use, and so using NFEs with code for the web in general is still problematic.)



Accessor Function Initializer (ES5+)



Sometimes functions can sneak in largely unnoticed; that's the case with accessor functions. Here's an example:



var obj = {
value: 0,
get f() {
return this.value;
},
set f(v) {
this.value = v;
}
};
console.log(obj.f); // 0
console.log(typeof obj.f); // "number"


Note that when I used the function, I didn't use ()! That's because it's an accessor function for a property. We get and set the property in the normal way, but behind the scenes, the function is called.



You can also create accessor functions with Object.defineProperty, Object.defineProperties, and the lesser-known second argument to Object.create.



Arrow Function Expression (ES2015+)



ES2015 brings us the arrow function. Here's one example:



var a = [1, 2, 3];
var b = a.map(n => n * 2);
console.log(b.join(", ")); // 2, 4, 6


See that n => n * 2 thing hiding in the map() call? That's a function.



A couple of things about arrow functions:




  1. They don't have their own this. Instead, they close over the this of the context where they're defined. (They also close over arguments and, where relevant, super.) This means that the this within them is the same as the this where they're created, and cannot be changed.


  2. As you'll have noticed with the above, you don't use the keyword function; instead, you use =>.



The n => n * 2 example above is one form of them. If you have multiple arguments to pass the function, you use parens:



var a = [1, 2, 3];
var b = a.map((n, i) => n * i);
console.log(b.join(", ")); // 0, 2, 6


(Remember that Array#map passes the entry as the first argument, and the index as the second.)



In both cases, the body of the function is just an expression; the function's return value will automatically be the result of that expression (you don't use an explicit return).



If you're doing more than just a single expression, use {} and an explicit return (if you need to return a value), as normal:



var a = [
{first: "Joe", last: "Bloggs"},
{first: "Albert", last: "Bloggs"},
{first: "Mary", last: "Albright"}
];
a = a.sort((a, b) => {
var rv = a.last.localeCompare(b.last);
if (rv === 0) {
rv = a.first.localeCompare(b.first);
}
return rv;
});
console.log(JSON.stringify(a));


The version without { ... } is called an arrow function with an expression body or concise body. (Also: A concise arrow function.) The one with { ... } defining the body is an arrow function with a function body. (Also: A verbose arrow function.)



Method Declaration in Object Initializer (ES2015+)



ES2015 allows a shorter form of declaring a property that references a function; it looks like this:



var o = {
foo() {
}
};


the equivalent in ES5 and earlier would be:



var o = {
foo: function foo() {
}
};


Constructor and Method Declarations in class (ES2015+)



ES2015 brings us class syntax, including declared constructors and methods:



class Person {
constructor(firstName, lastName) {
this.firstName = firstName;
this.lastName = lastName;
}

getFullName() {
return this.firstName + " " + this.lastName;
}
}


There are two function declarations above: One for the constructor, which gets the name Person, and one for getFullName, which is a function assigned to Person.prototype.






share|improve this answer



















  • 3




    then the name w is simply ignored ?
    – BiAiB
    Mar 4 '14 at 13:37






  • 8




    @PellePenna: Function names are useful for lots of things. The two biggies in my view are recursion, and the name of the function being shown in call stacks, exception traces, and such.
    – T.J. Crowder
    Mar 4 '14 at 13:42






  • 10




    This should now be the accepted answer. It's much more recent than the one above.
    – Chaim Eliyah
    Oct 2 '15 at 16:15






  • 4




    @ChaimEliyah - "Accepting doesn't mean it's the best answer, it just means that it worked for the person who asked." source
    – ScrapCode
    Feb 10 '16 at 10:19






  • 6




    @A.R.: Quite true. Amusingly, though, right above that it says "The best answers show up first so that they are always easy to find." Since the accepted answer shows up first even over higher-voted answers, the tour might be somewhat self-contradicting. ;-) Also a bit inaccurate, if we determine "best" by votes (which isn't reliable, it's just what we've got), "best" answers only show up first if you're using the "Votes" tab -- otherwise, the answers that are first are the active ones, or the oldest ones.
    – T.J. Crowder
    Feb 10 '16 at 10:32



















137














Speaking about the global context, both, the var statement and a FunctionDeclaration at the end will create a non-deleteable property on the global object, but the value of both can be overwritten.



The subtle difference between the two ways is that when the Variable Instantiation process runs (before the actual code execution) all identifiers declared with var will be initialized with undefined, and the ones used by the FunctionDeclaration's will be available since that moment, for example:



 alert(typeof foo); // 'function', it's already available
alert(typeof bar); // 'undefined'
function foo () {}
var bar = function () {};
alert(typeof bar); // 'function'


The assignment of the bar FunctionExpression takes place until runtime.



A global property created by a FunctionDeclaration can be overwritten without any problems just like a variable value, e.g.:



 function test () {}
test = null;


Another obvious difference between your two examples is that the first function doesn't have a name, but the second has it, which can be really useful when debugging (i.e. inspecting a call stack).



About your edited first example (foo = function() { alert('hello!'); };), it is an undeclared assignment, I would highly encourage you to always use the var keyword.



With an assignment, without the var statement, if the referenced identifier is not found in the scope chain, it will become a deleteable property of the global object.



Also, undeclared assignments throw a ReferenceError on ECMAScript 5 under Strict Mode.



A must read:




  • Named function expressions demystified


Note: This answer has been merged from another question, in which the major doubt and misconception from the OP was that identifiers declared with a FunctionDeclaration, couldn't be overwritten which is not the case.






share|improve this answer























  • I did not know that functions could be overwritten in JavaScript! Also, that parse order is the big selling point for me. I guess I need to watch how I create functions.
    – Xeoncross
    Aug 8 '10 at 19:43






  • 2




    +0 to the "Names function expressions demystified" article as it's 404ing. Possible mirror?: kangax.github.com/nfe
    – Mr_Chimp
    Nov 29 '11 at 15:10










  • @CMS Nice one. Bear in mind though I never saw the original so I don't know if that's a mirror or just another article with the same title!
    – Mr_Chimp
    Nov 29 '11 at 15:25










  • @Mr_Chimp I'm pretty sure it is, thewaybackmachine is saying that it got a 302 at crawl time and the redirection was to the link you provided.
    – John
    Jan 30 '12 at 15:18



















115














The two code snippets you've posted there will, for almost all purposes, behave the same way.



However, the difference in behaviour is that with the first variant (var functionOne = function() {}), that function can only be called after that point in the code.



With the second variant (function functionTwo()), the function is available to code that runs above where the function is declared.



This is because with the first variant, the function is assigned to the variable foo at run time. In the second, the function is assigned to that identifier, foo, at parse time.



More technical information



JavaScript has three ways of defining functions.




  1. Your first snippet shows a function expression. This involves using the "function" operator to create a function - the result of that operator can be stored in any variable or object property. The function expression is powerful that way. The function expression is often called an "anonymous function", because it does not have to have a name,

  2. Your second example is a function declaration. This uses the "function" statement to create a function. The function is made available at parse time and can be called anywhere in that scope. You can still store it in a variable or object property later.

  3. The third way of defining a function is the "Function()" constructor, which is not shown in your original post. It's not recommended to use this as it works the same way as eval(), which has its problems.






share|improve this answer































    96














    A better explanation to Greg's answer



    functionTwo();
    function functionTwo() {
    }


    Why no error? We were always taught that expressions are executed from top to bottom(??)



    Because:




    Function declarations and variable declarations are always moved (hoisted) invisibly to the top of their containing scope by the JavaScript interpreter. Function parameters and language-defined names are, obviously, already there. ben cherry




    This means that code like this:



    functionOne();                  ---------------      var functionOne;
    | is actually | functionOne();
    var functionOne = function(){ | interpreted |-->
    }; | like | functionOne = function(){
    --------------- };


    Notice that the assignment portion of the declarations were not hoisted. Only the name is hoisted.



    But in the case with function declarations, the entire function body will be hoisted as well:



    functionTwo();              ---------------      function functionTwo() {
    | is actually | };
    function functionTwo() { | interpreted |-->
    } | like | functionTwo();
    ---------------





    share|improve this answer























    • HI suhail thanks for clear info about function topic. Now my question is which one will be the first declaration in declaration hierarchy whether variable declaration (functionOne) or function declaration (functionTwo) ?
      – Sharathi RB
      Feb 2 '16 at 12:09



















    87














    Other commenters have already covered the semantic difference of the two variants above. I wanted to note a stylistic difference: Only the "assignment" variation can set a property of another object.



    I often build JavaScript modules with a pattern like this:



    (function(){
    var exports = {};

    function privateUtil() {
    ...
    }

    exports.publicUtil = function() {
    ...
    };

    return exports;
    })();


    With this pattern, your public functions will all use assignment, while your private functions use declaration.



    (Note also that assignment should require a semicolon after the statement, while declaration prohibits it.)






    share|improve this answer



















    • 4




      yuiblog.com/blog/2007/06/12/module-pattern is the primordial reference for the module pattern, as far as I can tell. (Though that article uses the var foo = function(){...} syntax even for private variables.
      – Sean McMillan
      Jun 3 '11 at 12:32










    • This isn't entirely true in some older versions of IE, actually. (function window.onload() {} was a thing.)
      – Ry-
      Apr 21 '13 at 19:42



















    73














    An illustration of when to prefer the first method to the second one is when you need to avoid overriding a function's previous definitions.



    With



    if (condition){
    function myfunction(){
    // Some code
    }
    }


    , this definition of myfunction will override any previous definition, since it will be done at parse-time.



    While



    if (condition){
    var myfunction = function (){
    // Some code
    }
    }


    does the correct job of defining myfunction only when condition is met.






    share|improve this answer



















    • 1




      this example is good and is close to perfection, but could be improved. the better example would be to defined var myFunc = null; outside of a loop, or outside of an if/elseif/else block. Then you can conditionally assign different functions to the same variable. In JS, it is a better convention to assign a missing value to null, then to undefined. Therefore, you should declare myFunction as null first, then assign it later, conditionally.
      – Alexander Mills
      May 26 '15 at 20:31





















    59














    An important reason is to add one and only one variable as the "Root" of your namespace...



    var MyNamespace = {}
    MyNamespace.foo= function() {

    }


    or



    var MyNamespace = {
    foo: function() {
    },
    ...
    }


    There are many techniques for namespacing. It's become more important with the plethora of JavaScript modules available.



    Also see How do I declare a namespace in JavaScript?






    share|improve this answer



















    • 3




      It appears this answer was merged into this question from another question, and the wording might seem to be a tiny bit unrelated to this question. Would you consider editing the answer so it seems more directed specifically at this question? (to reiterate; this isn't your fault at all... just a side-effect of a merged question). You can also delete it, and I think you would keep your reputation. Or you can leave it; since it's old, it may not make a big difference.
      – Andrew Barber
      May 29 '13 at 21:13



















    52














    Hoisting is the JavaScript interpreter’s action of moving all variable and function declarations to the top of the current scope.



    However, only the actual declarations are hoisted. by leaving assignments where they are.




    • variable's/Function's declared inside the page are global can access anywhere in that page.

    • variable's/Functions declared inside the function are having local scope. means they are available/accessed inside the function body (scope), they are not available outside the function body.


    Variable



    Javascript is called loosely typed language. Which means Javascript variables can hold value of any Data-Type. Javascript automatically takes care of changing the variable-type based on the value/literal provided during runtime.



    global_Page = 10;                                               var global_Page;      « undefined
    « Integer literal, Number Type. ------------------- global_Page = 10; « Number
    global_Page = 'Yash'; | Interpreted | global_Page = 'Yash'; « String
    « String literal, String Type. « AS « global_Page = true; « Boolean
    var global_Page = true; | | global_Page = function (){ « function
    « Boolean Type ------------------- var local_functionblock; « undefined
    global_Page = function (){ local_functionblock = 777;« Number
    var local_functionblock = 777; };
    // Assigning function as a data.
    };




    Function



    function Identifier_opt ( FormalParameterList_opt ) { 
    FunctionBody | sequence of statements

    « return; Default undefined
    « return 'some data';
    }



    • functions declared inside the page are hoisted to top of the page having global access.

    • functions declared inside the function-block are hoisted to top of the block.


    • Default return value of function is 'undefined', Variable declaration default value also 'undefined'



      Scope with respect to function-block global. 
      Scope with respect to page undefined | not available.



    Function Declaration



    function globalAccess() {                                  function globalAccess() {      
    } ------------------- }
    globalAccess(); | | function globalAccess() { « Re-Defined / overridden.
    localAccess(); « Hoisted As « function localAccess() {
    function globalAccess() { | | }
    localAccess(); ------------------- localAccess(); « function accessed with in globalAccess() only.
    function localAccess() { }
    } globalAccess();
    } localAccess(); « ReferenceError as the function is not defined


    Function Expression



            10;                 « literal
    (10); « Expression (10).toString() -> '10'
    var a;
    a = 10; « Expression var a.toString() -> '10'
    (function invoke() { « Expression Function
    console.log('Self Invoking'); (function () {
    }); }) () -> 'Self Invoking'

    var f;
    f = function (){ « Expression var Function
    console.log('var Function'); f () -> 'var Function'
    };


    Function assigned to variable Example:



    (function selfExecuting(){
    console.log('IIFE - Immediately-Invoked Function Expression');
    }());

    var anonymous = function (){
    console.log('anonymous function Expression');
    };

    var namedExpression = function for_InternalUSE(fact){
    if(fact === 1){
    return 1;
    }

    var localExpression = function(){
    console.log('Local to the parent Function Scope');
    };
    globalExpression = function(){
    console.log('creates a new global variable, then assigned this function.');
    };

    //return; //undefined.
    return fact * for_InternalUSE( fact - 1);
    };

    namedExpression();
    globalExpression();


    javascript interpreted as



    var anonymous;
    var namedExpression;
    var globalExpression;

    anonymous = function (){
    console.log('anonymous function Expression');
    };

    namedExpression = function for_InternalUSE(fact){
    var localExpression;

    if(fact === 1){
    return 1;
    }
    localExpression = function(){
    console.log('Local to the parent Function Scope');
    };
    globalExpression = function(){
    console.log('creates a new global variable, then assigned this function.');
    };

    return fact * for_InternalUSE( fact - 1); // DEFAULT UNDEFINED.
    };

    namedExpression(10);
    globalExpression();


    You can check function declaration, expression test over different browser's using jsperf Test Runner





    ES5 Constructor Function Classes: Function objects created using Function.prototype.bind



    JavaScript treats functions as first-class objects, so being an object, you can assign properties to a function.



    function Shape(id) { // Function Declaration
    this.id = id;
    };
    // Adding a prototyped method to a function.
    Shape.prototype.getID = function () {
    return this.id;
    };
    Shape.prototype.setID = function ( id ) {
    this.id = id;
    };

    var expFn = Shape; // Function Expression

    var funObj = new Shape( ); // Function Object
    funObj.hasOwnProperty('prototype'); // false
    funObj.setID( 10 );
    console.log( funObj.getID() ); // 10




    ES6 introduced Arrow function: An arrow function expression has a shorter syntax, they are best suited for non-method functions, and they cannot be used as constructors.




    ArrowFunction : ArrowParameters => ConciseBody.



    const fn = (item) => { return item & 1 ? 'Odd' : 'Even'; };
    console.log( fn(2) ); // Even
    console.log( fn(3) ); // Odd






    share|improve this answer



















    • 3




      ahm, your answer... isn't it ambiguous? well written though so +1 for spending and writing too much info.
      – Danish
      Jan 31 '16 at 17:56



















    36














    I'm adding my own answer just because everyone else has covered the hoisting part thoroughly.



    I've wondered about which way is better for a long while now, and thanks to http://jsperf.com now I know :)



    enter image description here



    Function declarations are faster, and that's what really matters in web dev right? ;)






    share|improve this answer

















    • 7




      I'd say that maintainability is the most important aspect of most code. Performance is important, but in most cases IO is likely to be a bigger bottleneck that the way you define your functions. However there are some problems where you need every bit of performance you can get and this is useful in those cases. Also good to have an answer here that answers clearly a well defined part of the question.
      – Richard Garside
      May 2 '15 at 15:22






    • 3




      Well, I found it to be other way around with Firefox. jsperf.com/sandytest
      – Sandeep Nayak
      Nov 17 '15 at 14:15






    • 2




      Microbenchmarks always fail. Looking to jsperf.com is waster of time. What you really need is to look to JS engine source code, official documentation, or at least sniff dev blogs or mail lists.
      – gavenkoa
      Jan 10 '16 at 15:13












    • Just an update, since I've gone full functional programming style in JavaScript now, I never use declarations, only function expressions so I can chain and call my functions by their variable names. Check out RamdaJS...
      – Leon Gaban
      Dec 28 '16 at 16:56










    • @SandeepNayak I just run your own test in Firefox 50.0.0 / Windows 7 0.0.0, and it actually is the same way as Leon's. So if your test is correct, I would conclude that jsperf's tests are not indicatives, and it all depend on your browser and / or OS version, or in the particular state of the current machine in that particular moment.
      – ocramot
      Jan 10 '17 at 13:40





















    32














    A function declaration and a function expression assigned to a variable behave the same once the binding is established.



    There is a difference however at how and when the function object is actually associated with its variable. This difference is due to the mechanism called variable hoisting in JavaScript.



    Basically, all function declarations and variable declarations are hoisted to the top of the function in which the declaration occurs (this is why we say that JavaScript has function scope).




    • When a function declaration is hoisted, the function body "follows"
      so when the function body is evaluated, the variable will immediately
      be bound to a function object.


    • When a variable declaration is hoisted, the initialization does not
      follow, but is "left behind". The variable is initialized to
      undefined at the start of the function body, and will be assigned
      a value at its original location in the code. (Actually, it will be assigned a value at every location where a declaration of a variable with the same name occurs.)



    The order of hoisting is also important: function declarations take precedence over variable declarations with the same name, and the last function declaration takes precedence over previous function declarations with the same name.



    Some examples...



    var foo = 1;
    function bar() {
    if (!foo) {
    var foo = 10 }
    return foo; }
    bar() // 10


    Variable foo is hoisted to the top of the function, initialized to undefined, so that !foo is true, so foo is assigned 10. The foo outside of bar's scope plays no role and is untouched.



    function f() {
    return a;
    function a() {return 1};
    var a = 4;
    function a() {return 2}}
    f()() // 2

    function f() {
    return a;
    var a = 4;
    function a() {return 1};
    function a() {return 2}}
    f()() // 2


    Function declarations take precedence over variable declarations, and the last function declaration "sticks".



    function f() {
    var a = 4;
    function a() {return 1};
    function a() {return 2};
    return a; }
    f() // 4


    In this example a is initialized with the function object resulting from evaluating the second function declaration, and then is assigned 4.



    var a = 1;
    function b() {
    a = 10;
    return;
    function a() {}}
    b();
    a // 1


    Here the function declaration is hoisted first, declaring and initializing variable a. Next, this variable is assigned 10. In other words: the assignment does not assign to outer variable a.






    share|improve this answer

















    • 2




      You have a bit weird way to place the closing braces. Are you a Python coder? It looks like you try to make Javascript look like Python. I am afraid it is confusing for other people. If I had to maintain your JavaScript code I would let your code through an automatic prettyprinter first.
      – nalply
      May 14 '13 at 12:46






    • 1




      Excellent post. A 'self-executing function' or 'immediately invoked function expression' should be easy enough to see and his style preference should not detract from his post - which is accurate and summarizes 'hoisting' perfectly. +1
      – Ricalsin
      Dec 17 '13 at 18:13



















    30














    The first example is a function declaration:



    function abc(){}


    The second example is a function expression:



    var abc = function() {};


    The main difference is how they are hoisted (lifted and declared). In the first example, the whole function declaration is hoisted. In the second example only the var 'abc' is hoisted, its value (the function) will be undefined, and the function itself remains at the position that it is declared.



    To put it simply:



    //this will work
    abc(param);
    function abc(){}

    //this would fail
    abc(param);
    var abc = function() {}


    To study more about this topic I strongly recommend you this
    link






    share|improve this answer



















    • 1




      Your example is kind of the same as the top answer
      – GôTô
      Jun 5 '14 at 8:34










    • The main reason for posting this answer was to provide the link at the bottom. This was the piece that was missing for me to fully understand the above question.
      – sla55er
      Jun 8 '14 at 5:44






    • 1




      It's very cool that you wanted to share the link. But links to additional information, in SO, should just be a comment on either the question or your favorite answer. It's very much sub-optimal to clutter a long, complicated page like this with repeated information just to add a single useful link at the end of it. No, you won't get rep points for providing the link, but you'll be helping the community.
      – XML
      Jan 13 '15 at 0:26



















    28














    In terms of code maintenance cost, named functions are more preferable:




    • Independent from the place where they are declared (but still limited by scope).

    • More resistant to mistakes like conditional initialization (you are still able to override if wanted to).

    • The code becomes more readable by allocating local functions separately of scope functionality. Usually in the scope the functionality goes first, followed by declarations of local functions.

    • In a debugger you will clearly see the function name on the call stack instead of an "anonymous/evaluated" function.


    I suspect more PROS for named functions are follow. And what is listed as an advantage of named functions is a disadvantage for anonymous ones.



    Historically, anonymous functions appeared from the inability of JavaScript as a language to list members with named functions:



    {
    member:function() { /* How do I make "this.member" a named function? */
    }
    }





    share|improve this answer



















    • 2




      There are the test to confirm: blog.firsov.net/2010/01/… JS performance test - scope and named functions - Analytics
      – Sasha Firsov
      Feb 4 '10 at 0:45





















    24














    I use the variable approach in my code for a very specific reason, the theory of which has been covered in an abstract way above, but an example might help some people like me, with limited JavaScript expertise.



    I have code that I need to run with 160 independently-designed brandings. Most of the code is in shared files, but branding-specific stuff is in a separate file, one for each branding.



    Some brandings require specific functions, and some do not. Sometimes I have to add new functions to do new branding-specific things. I am happy to change the shared coded, but I don't want to have to change all 160 sets of branding files.



    By using the variable syntax, I can declare the variable (a function pointer essentially) in the shared code and either assign a trivial stub function, or set to null.



    The one or two brandings that need a specific implementation of the function can then define their version of the function and assign this to the variable if they want, and the rest do nothing. I can test for a null function before I execute it in the shared code.



    From people's comments above, I gather it may be possible to redefine a static function too, but I think the variable solution is nice and clear.






    share|improve this answer































      22














      In computer science terms, we talk about anonymous functions and named functions. I think the most important difference is that an anonymous function is not bound to an name, hence the name anonymous function. In JavaScript it is a first class object dynamically declared at runtime.



      For more information on anonymous functions and lambda calculus, Wikipedia is a good start (http://en.wikipedia.org/wiki/Anonymous_function).






      share|improve this answer































        22














        Greg's Answer is good enough, but I still would like to add something to it that I learned just now watching Douglas Crockford's videos.



        Function expression:



        var foo = function foo() {};


        Function statement:



        function foo() {};


        The function statement is just a shorthand for var statement with a function value.



        So



        function foo() {};


        expands to



        var foo = function foo() {};


        Which expands further to:



        var foo = undefined;
        foo = function foo() {};


        And they are both hoisted to the top of the code.



        Screenshot from video






        share|improve this answer



















        • 7




          Sorry but this is incorrect - I don't know what Crockford is trying to say in that slide. Both function & variable declarations are always hoisted to top of their scope. The difference is that variable assignments (whether you are assigning it with a string, boolean or function) are not hoisted to the top whereas function bodies (using function declaration) are.
          – Thomas Heymann
          Oct 5 '15 at 16:25












        • Have a look at these code examples: gist.github.com/cyberthom/36603fbc20de8e04fd09
          – Thomas Heymann
          Oct 5 '15 at 16:51





















        18














        @EugeneLazutkin gives an example where he names an assigned function to be able to use shortcut() as an internal reference to itself. John Resig gives another example - copying a recursive function assigned to another object in his Learning Advanced Javascript tutorial. While assigning functions to properties isn't strictly the question here, I recommend actively trying the tutorial out - run the code by clicking the button in the upper right corner, and double click the code to edit to your liking.



        Examples from the tutorial: recursive calls in yell():



        Tests fail when the original ninja object is removed. (page 13)



        var ninja = { 
        yell: function(n){
        return n > 0 ? ninja.yell(n-1) + "a" : "hiy";
        }
        };
        assert( ninja.yell(4) == "hiyaaaa", "A single object isn't too bad, either." );

        var samurai = { yell: ninja.yell };
        var ninja = null;

        try {
        samurai.yell(4);
        } catch(e){
        assert( false, "Uh, this isn't good! Where'd ninja.yell go?" );
        }


        If you name the function that will be called recursively, the tests will pass. (page 14)



        var ninja = { 
        yell: function yell(n){
        return n > 0 ? yell(n-1) + "a" : "hiy";
        }
        };
        assert( ninja.yell(4) == "hiyaaaa", "Works as we would expect it to!" );

        var samurai = { yell: ninja.yell };
        var ninja = {};
        assert( samurai.yell(4) == "hiyaaaa", "The method correctly calls itself." );





        share|improve this answer























        • Just calling this.yell works too :)
          – Ry-
          Apr 21 '13 at 20:54



















        15














        Another difference that is not mentioned in the other answers is that if you use the anonymous function



        var functionOne = function() {
        // Some code
        };


        and use that as a constructor as in



        var one = new functionOne();


        then one.constructor.name will not be defined. Function.name is non-standard but is supported by Firefox, Chrome, other Webkit-derived browsers and IE 9+.



        With



        function functionTwo() {
        // Some code
        }
        two = new functionTwo();


        it is possible to retrieve the name of the constructor as a string with two.constructor.name.






        share|improve this answer























        • The name in the first case will not be defined because its an anonymous function assigned to a variable. I think the word anonymous was invented for things that don't have their name defined :)
          – Om Shankar
          Jan 17 '13 at 6:13










        • In this example the two=new becomes a global function because no var
          – Waqas Tahir
          Aug 29 '15 at 5:04



















        14














        If you would use those functions to create objects, you would get:



        var objectOne = new functionOne();
        console.log(objectOne.__proto__); // prints "Object {}" because constructor is an anonymous function

        var objectTwo = new functionTwo();
        console.log(objectTwo.__proto__); // prints "functionTwo {}" because constructor is a named function





        share|improve this answer





















        • I can't seem to reproduce this. console.log(objectOne.__proto__); prints "functionOne {}" in my console. Any ideas of why this may be the case?
          – Mike
          Mar 22 '15 at 10:06












        • I can't seem to reproduce it as well.
          – daremkd
          Jan 21 '16 at 15:57






        • 1




          This is a capability of your debugger (to display the "class" of the logged object), and most ones are able to derive a name even for anonymous function expressions these days. Btw, you should make clear that there is no functional difference between the two instances.
          – Bergi
          Jan 21 '16 at 16:26



















        14














        The first one (function doSomething(x)) should be part of an object notation.



        The second one (var doSomething = function(x){ alert(x);}) is simply creating an anonymous function and assigning it to a variable, doSomething. So doSomething() will call the function.



        You may want to know what a function declaration and function expression is.



        A function declaration defines a named function variable without requiring variable assignment. Function declarations occur as standalone constructs and cannot be nested within non-function blocks.



        function foo() {
        return 3;
        }



        ECMA 5 (13.0) defines the syntax as

        function Identifier ( FormalParameterListopt ) { FunctionBody }




        In above condition the function name is visible within its scope and the scope of its parent (otherwise it would be unreachable).



        And in a function expression



        A function expression defines a function as a part of a larger expression syntax (typically a variable assignment ). Functions defined via functions expressions can be named or anonymous. Function expressions should not start with “function”.



        // Anonymous function expression
        var a = function() {
        return 3;
        }

        // Named function expression
        var a = function foo() {
        return 3;
        }

        // Self-invoking function expression
        (function foo() {
        alert("hello!");
        })();



        ECMA 5 (13.0) defines the syntax as

        function Identifieropt ( FormalParameterListopt ) { FunctionBody }







        share|improve this answer































          14














          I'm listing out the differences below:





          1. A function declaration can be placed anywhere in the code. Even if it is invoked before the definition appears in code, it gets executed as function declaration is committed to memory or in a way it is hoisted up, before any other code in the page starts execution.



            Take a look at the function below:



            function outerFunction() {
            function foo() {
            return 1;
            }
            return foo();
            function foo() {
            return 2;
            }
            }
            alert(outerFunction()); // Displays 2


            This is because, during execution, it looks like:-



            function foo() {  // The first function declaration is moved to top
            return 1;
            }
            function foo() { // The second function declaration is moved to top
            return 2;
            }
            function outerFunction() {
            return foo();
            }
            alert(outerFunction()); //So executing from top to bottom,
            //the last foo() returns 2 which gets displayed


            A function expression, if not defined before calling it, will result in an error. Also, here the function definition itself is not moved to the top or committed to memory like in the function declarations. But the variable to which we assign the function gets hoisted up and undefined gets assigned to it.



            Same function using function expressions:



            function outerFunction() {
            var foo = function() {
            return 1;
            }
            return foo();
            var foo = function() {
            return 2;
            }
            }
            alert(outerFunction()); // Displays 1


            This is because during execution, it looks like:



            function outerFunction() {
            var foo = undefined;
            var foo = undefined;

            foo = function() {
            return 1;
            };
            return foo ();
            foo = function() { // This function expression is not reachable
            return 2;
            };
            }
            alert(outerFunction()); // Displays 1



          2. It is not safe to write function declarations in non-function blocks like if because they won't be accessible.



            if (test) {
            function x() { doSomething(); }
            }



          3. Named function expression like the one below, may not work in Internet Explorer browsers prior to version 9.



            var today = function today() {return new Date()}







          share|improve this answer



















          • 1




            @Arjun What's the problem if a question was asked years earlier ? An answer doesn't only benefit the OP but potentially all SO users, no matter when the question was asked. And what's wrong with answering questions that already have an accepted answer ?
            – SantiBailors
            Oct 5 '15 at 12:58






          • 1




            @Arjun you got to understand answering old questions is not bad. If it were to be, SO would have had such a barrier. Imagine there is a change in API(albeit not in this question's context) and someone spots it and provides an answer with the new API, shouldn't that be allowed?? Until and unless the answer doesn't make sense and doesn't belong here, it would be downvoted and removed automatically. You don't need to bother with it!!!!
            – Sudhansu Choudhary
            Oct 18 '15 at 21:37



















          12














          In light of the "named functions show up in stack traces" argument, modern JavaScript engines are actually quite capable of representing anonymous functions.



          As of this writing, V8, SpiderMonkey, Chakra and Nitro always refer to named functions by their names. They almost always refer to an anonymous function by its identifier if it has one.



          SpiderMonkey can figure out the name of an anonymous function returned from another function. The rest can't.



          If you really, really wanted your iterator and success callbacks to show up in the trace, you could name those too...



          .forEach(function iterator() {});


          But for the most part it's not worth stressing over.



          Harness (Fiddle)



          'use strict';

          var a = function () {
          throw new Error();
          },
          b = function b() {
          throw new Error();
          },
          c = function d() {
          throw new Error();
          },
          e = {
          f: a,
          g: b,
          h: c,
          i: function () {
          throw new Error();
          },
          j: function j() {
          throw new Error();
          },
          k: function l() {
          throw new Error();
          }
          },
          m = (function () {
          return function () {
          throw new Error();
          };
          }()),
          n = (function () {
          return function n() {
          throw new Error();
          };
          }()),
          o = (function () {
          return function p() {
          throw new Error();
          };
          }());

          console.log([a, b, c].concat(Object.keys(e).reduce(function (values, key) {
          return values.concat(e[key]);
          }, )).concat([m, n, o]).reduce(function (logs, func) {

          try {
          func();
          } catch (error) {
          return logs.concat('func.name: ' + func.name + 'n' +
          'Trace:n' +
          error.stack);
          // Need to manually log the error object in Nitro.
          }

          }, ).join('nn'));


          V8



          func.name: 
          Trace:
          Error
          at a (http://localhost:8000/test.js:4:11)
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27

          func.name: b
          Trace:
          Error
          at b (http://localhost:8000/test.js:7:15)
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27

          func.name: d
          Trace:
          Error
          at d (http://localhost:8000/test.js:10:15)
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27

          func.name:
          Trace:
          Error
          at a (http://localhost:8000/test.js:4:11)
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27

          func.name: b
          Trace:
          Error
          at b (http://localhost:8000/test.js:7:15)
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27

          func.name: d
          Trace:
          Error
          at d (http://localhost:8000/test.js:10:15)
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27

          func.name:
          Trace:
          Error
          at e.i (http://localhost:8000/test.js:17:19)
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27

          func.name: j
          Trace:
          Error
          at j (http://localhost:8000/test.js:20:19)
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27

          func.name: l
          Trace:
          Error
          at l (http://localhost:8000/test.js:23:19)
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27

          func.name:
          Trace:
          Error
          at http://localhost:8000/test.js:28:19
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27

          func.name: n
          Trace:
          Error
          at n (http://localhost:8000/test.js:33:19)
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27

          func.name: p
          Trace:
          Error
          at p (http://localhost:8000/test.js:38:19)
          at http://localhost:8000/test.js:47:9
          at Array.reduce (native)
          at http://localhost:8000/test.js:44:27 test.js:42


          SpiderMonkey



          func.name: 
          Trace:
          a@http://localhost:8000/test.js:4:5
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          func.name: b
          Trace:
          b@http://localhost:8000/test.js:7:9
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          func.name: d
          Trace:
          d@http://localhost:8000/test.js:10:9
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          func.name:
          Trace:
          a@http://localhost:8000/test.js:4:5
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          func.name: b
          Trace:
          b@http://localhost:8000/test.js:7:9
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          func.name: d
          Trace:
          d@http://localhost:8000/test.js:10:9
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          func.name:
          Trace:
          e.i@http://localhost:8000/test.js:17:13
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          func.name: j
          Trace:
          j@http://localhost:8000/test.js:20:13
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          func.name: l
          Trace:
          l@http://localhost:8000/test.js:23:13
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          func.name:
          Trace:
          m</<@http://localhost:8000/test.js:28:13
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          func.name: n
          Trace:
          n@http://localhost:8000/test.js:33:13
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          func.name: p
          Trace:
          p@http://localhost:8000/test.js:38:13
          @http://localhost:8000/test.js:47:9
          @http://localhost:8000/test.js:54:1


          Chakra



          func.name: undefined
          Trace:
          Error
          at a (http://localhost:8000/test.js:4:5)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          func.name: undefined
          Trace:
          Error
          at b (http://localhost:8000/test.js:7:9)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          func.name: undefined
          Trace:
          Error
          at d (http://localhost:8000/test.js:10:9)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          func.name: undefined
          Trace:
          Error
          at a (http://localhost:8000/test.js:4:5)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          func.name: undefined
          Trace:
          Error
          at b (http://localhost:8000/test.js:7:9)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          func.name: undefined
          Trace:
          Error
          at d (http://localhost:8000/test.js:10:9)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          func.name: undefined
          Trace:
          Error
          at e.i (http://localhost:8000/test.js:17:13)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          func.name: undefined
          Trace:
          Error
          at j (http://localhost:8000/test.js:20:13)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          func.name: undefined
          Trace:
          Error
          at l (http://localhost:8000/test.js:23:13)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          func.name: undefined
          Trace:
          Error
          at Anonymous function (http://localhost:8000/test.js:28:13)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          func.name: undefined
          Trace:
          Error
          at n (http://localhost:8000/test.js:33:13)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          func.name: undefined
          Trace:
          Error
          at p (http://localhost:8000/test.js:38:13)
          at Anonymous function (http://localhost:8000/test.js:47:9)
          at Global code (http://localhost:8000/test.js:42:1)


          Nitro



          func.name: 
          Trace:
          a@http://localhost:8000/test.js:4:22
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33

          func.name: b
          Trace:
          b@http://localhost:8000/test.js:7:26
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33

          func.name: d
          Trace:
          d@http://localhost:8000/test.js:10:26
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33

          func.name:
          Trace:
          a@http://localhost:8000/test.js:4:22
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33

          func.name: b
          Trace:
          b@http://localhost:8000/test.js:7:26
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33

          func.name: d
          Trace:
          d@http://localhost:8000/test.js:10:26
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33

          func.name:
          Trace:
          i@http://localhost:8000/test.js:17:30
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33

          func.name: j
          Trace:
          j@http://localhost:8000/test.js:20:30
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33

          func.name: l
          Trace:
          l@http://localhost:8000/test.js:23:30
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33

          func.name:
          Trace:
          http://localhost:8000/test.js:28:30
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33

          func.name: n
          Trace:
          n@http://localhost:8000/test.js:33:30
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33

          func.name: p
          Trace:
          p@http://localhost:8000/test.js:38:30
          http://localhost:8000/test.js:47:13
          reduce@[native code]
          global code@http://localhost:8000/test.js:44:33





          share|improve this answer































            10














            In JavaScript there are two ways to create functions:





            1. Function declaration:



              function fn(){
              console.log("Hello");
              }
              fn();


              This is very basic, self-explanatory, used in many languages and standard across C family of languages. We declared a function defined it and executed it by calling it.



              What you should be knowing is that functions are actually objects in JavaScript; internally we have created an object for above function and given it a name called fn or the reference to the object is stored in fn. Functions are objects in JavaScript; an instance of function is actually an object instance.




            2. Function expression:



              var fn=function(){
              console.log("Hello");
              }
              fn();


              JavaScript has first-class functions, that is, create a function and assign it to a variable just like you create a string or number and assign it to a variable. Here, the fn variable is assigned to a function. The reason for this concept is functions are objects in JavaScript; fn is pointing to the object instance of the above function. We have initialized a function and assigned it to a variable. It's not executing the function and assigning the result.




            Reference: JavaScript function declaration syntax: var fn = function() {} vs function fn() {}






            share|improve this answer



















            • 1




              what about the third option, var fn = function fn() {...}?
              – chharvey
              Aug 20 '16 at 0:40










            • Hi Chharvey, not sure about ur question, I guess u r talking about function expression which I have already mentioned. However, if still there is some confusion just be more elaborative.
              – Anoop Rai
              Aug 23 '16 at 10:00










            • yes I was asking about a named function expression. it's similar to your option #2 except that the function has an identifier. usually this identifier is the same as the variable it's being assigned to, but that's not always the case.
              – chharvey
              Aug 23 '16 at 10:39






            • 1




              Yes Named function expression is similar to my option #2. Well having an identifier is not mandatory as it's not used. Whenever you will be executing the function expression you will use the variable holding the function object. Identifier serves no purpose.
              – Anoop Rai
              Aug 23 '16 at 11:42





















            10














            There are four noteworthy comparisons between the two different declarations of functions as listed below.




            1. Availability (scope) of the function


            The following works because function add() is scoped to the nearest block:






            try {
            console.log("Success: ", add(1, 1));
            } catch(e) {
            console.log("ERROR: " + e);
            }

            function add(a, b){
            return a + b;
            }





            The following does not works (because the var add= superseeds the function add()).






            try {
            console.log("Success: ", add(1, 1));
            } catch(e) {
            console.log("ERROR: " + e);
            }

            var add=function add(a, b){
            return a + b;
            }





            The following does not work because add is declared after it is used.






            try {
            console.log("Success: ", add(1, 1));
            } catch(e) {
            console.log("ERROR: " + e);
            }

            var add=function(a, b){
            return a + b;
            }







            1. (function).name


            The name of a function function thefuncname(){} is thefuncname when it is declared this way.






            function foobar(a, b){}

            console.log(foobar.name);








            var a = function foobar(){};

            console.log(a.name);





            Otherwise, if a function is declared as function(){}, the function.name is the first variable used to store the function.






            var a = function(){};
            var b = (function(){ return function(){} });

            console.log(a.name);
            console.log(b.name);





            If there are no variables set to the function, then the functions name is the empty string ("").






            console.log((function(){}).name === "");





            Lastly, while the variable the function is assigned to initially sets the name, successive variables set to the function do not change the name.






            var a = function(){};
            var b = a;
            var c = b;

            console.log(a.name);
            console.log(b.name);
            console.log(c.name);






            1. Performance


            In Google's V8 and Firefox's Spidermonkey there might be a few microsecond JIST compilation difference, but ultimately the result is the exact same. To prove this, let's examine the efficiency of JSPerf at microbenchmarks by comparing the speed of two blank code snippets. The JSPerf tests are found here. And, the jsben.ch testsare found here. As you can see, there is a noticable difference when there should be none. If you are really a performance freak like me, then it might be more worth your while trying to reduce the number of variables and functions in the scope and especially eliminating polymorphism (such as using the same variable to store two different types).




            1. Variable Mutability


            When you use the var keyword to declare a variable, you can then reassign a different value to the variable like so.






            (function(){
            "use strict";
            var foobar = function(){}; // initial value
            try {
            foobar = "Hello World!"; // new value
            console.log("[no error]");
            } catch(error) {
            console.log("ERROR: " + error.message);
            }
            console.log(foobar, window.foobar);
            })();





            However, when we use the const-statement, the variable reference becomes immutable. This means that we cannot assign a new value to the variable. Please note, however, that this does not make the contents of the variable immutable: if you do const arr = , then you can still do arr[10] = "example". Only doing something like arr = "new value" or arr = would throw an error as seen below.






            (function(){
            "use strict";
            const foobar = function(){}; // initial value
            try {
            foobar = "Hello World!"; // new value
            console.log("[no error]");
            } catch(error) {
            console.log("ERROR: " + error.message);
            }
            console.log(foobar, window.foobar);
            })();





            Interestingly, if we declare the variable as function funcName(){}, then the immutability of the variable is the same as declaring it with var.






            (function(){
            "use strict";
            function foobar(){}; // initial value
            try {
            foobar = "Hello World!"; // new value
            console.log("[no error]");
            } catch(error) {
            console.log("ERROR: " + error.message);
            }
            console.log(foobar, window.foobar);
            })();





            What Is The "Nearest Block"



            The "nearest block" is the nearest "function," (including asynchronous functions, generator functions, and asynchronous generator functions). However, interestingly, a function functionName() {} behaves like a var functionName = function() {} when in a non-closure block to items outside said closure. Observe.




            • Normal var add=function(){}





            try {
            // typeof will simply return "undefined" if the variable does not exist
            if (typeof add !== "undefined") {
            add(1, 1); // just to prove it
            console.log("Not a block");
            }else if(add===undefined){ // this throws an exception if add doesn't exist
            console.log('Behaves like var add=function(a,b){return a+b}');
            }
            } catch(e) {
            console.log("Is a block");
            }
            var add=function(a, b){return a + b}






            • Normal function add(){}





            try {
            // typeof will simply return "undefined" if the variable does not exist
            if (typeof add !== "undefined") {
            add(1, 1); // just to prove it
            console.log("Not a block");
            }else if(add===undefined){ // this throws an exception if add doesn't exist
            console.log('Behaves like var add=function(a,b){return a+b}')
            }
            } catch(e) {
            console.log("Is a block");
            }
            function add(a, b){
            return a + b;
            }






            • Function





            try {
            // typeof will simply return "undefined" if the variable does not exist
            if (typeof add !== "undefined") {
            add(1, 1); // just to prove it
            console.log("Not a block");
            }else if(add===undefined){ // this throws an exception if add doesn't exist
            console.log('Behaves like var add=function(a,b){return a+b}')
            }
            } catch(e) {
            console.log("Is a block");
            }
            (function () {
            function add(a, b){
            return a + b;
            }
            })();






            • Statement (such as if, else, for, while, try/catch/finally, switch, do/while, with)





            try {
            // typeof will simply return "undefined" if the variable does not exist
            if (typeof add !== "undefined") {
            add(1, 1); // just to prove it
            console.log("Not a block");
            }else if(add===undefined){ // this throws an exception if add doesn't exist
            console.log('Behaves like var add=function(a,b){return a+b}')
            }
            } catch(e) {
            console.log("Is a block");
            }
            {
            function add(a, b){
            return a + b;
            }
            }






            • Arrow Function with var add=function()





            try {
            // typeof will simply return "undefined" if the variable does not exist
            if (typeof add !== "undefined") {
            add(1, 1); // just to prove it
            console.log("Not a block");
            }else if(add===undefined){ // this throws an exception if add doesn't exist
            console.log('Behaves like var add=function(a,b){return a+b}')
            }
            } catch(e) {
            console.log("Is a block");
            }
            (() => {
            var add=function(a, b){
            return a + b;
            }
            })();






            • Arrow Function With function add()





            try {
            // typeof will simply return "undefined" if the variable does not exist
            if (typeof add !== "undefined") {
            add(1, 1); // just to prove it
            console.log("Not a block");
            }else if(add===undefined){ // this throws an exception if add doesn't exist
            console.log('Behaves like var add=function(a,b){return a+b}')
            }
            } catch(e) {
            console.log("Is a block");
            }
            (() => {
            function add(a, b){
            return a + b;
            }
            })();








            share|improve this answer































              8














              Both are different ways of defining a function. The difference is how the browser interprets and loads them into an execution context.



              The first case is of function expressions which loads only when the interpreter reaches that line of code. So if you do it like the following, you will get an error that the functionOne is not a function.



              functionOne();
              var functionOne = function() {
              // Some code
              };


              The reason is that on the first line no value is assigned to functionOne, and hence it is undefined. We are trying to call it as a function, and hence we are getting an error.



              On the second line we are assigning the reference of an anonymous function to functionOne.



              The second case is of function declarations that loads before any code is executed. So if you do like the following you won't get any error as the declaration loads before code execution.



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





              share|improve this answer































                8














                About performance:



                New versions of V8 introduced several under-the-hood optimizations and so did SpiderMonkey.



                There is almost no difference now between expression and declaration.
                Function expression appears to be faster now.



                Chrome 62.0.3202
                Chrome test



                FireFox 55
                Firefox test



                Chrome Canary 63.0.3225
                Chrome Canary test







                Anonymous function expressions appear to have better performance
                against Named function expression.







                Firefox
                Firefox named_anonymousChrome Canary
                Chrome canary named_anonymousChrome
                Chrome named_anonymous






                share|improve this answer



















                • 1




                  Yes, this difference is so insignificant that hopefully devs will concern themselves with which approach is more maintainable for their specific needs rather than which one might be faster (you'll get different jsperf results on each try depending on what the browser is doing -- the majority of javascript tasks needn't concern themselves with micro-optimizations to this degree).
                  – squidbe
                  Nov 26 '17 at 1:41












                • @squidbe There is no difference. Look here: jsperf.com/empty-tests-performance
                  – Jack Giffin
                  May 10 at 21:10



















                7














                They are pretty similar with some small differences, first one is a variable which assigned to an anonymous function (Function Declaration) and second one is the normal way to create a function in JavaScript(Anonymous function Declaration), both has usage, cons and pros:



                1. Function Expression



                var functionOne = function() {
                // Some code
                };



                A Function Expression defines a function as a part of a larger
                expression syntax (typically a variable assignment ). Functions
                defined via Functions Expressions can be named or anonymous. Function
                Expressions must not start with “function” (hence the parentheses
                around the self invoking example below).




                Assign a variable to a function, means no Hoisting, as we know functions in JavaScript can Hoist, means they can be called before they get declared, while variables need to be declared before getting access to them, so means in this case we can not access the function before where it's declared, also it could be a way that you write your functions, for the functions which return another function, this kind of declaration could make sense, also in ECMA6 & above you can assign this to an arrow function which can be used to call anonymous functions, also this way of declaring is a better way to create Constructor functions in JavaScript.



                2. Function Declaration



                function functionTwo() {
                // Some code
                }



                A Function Declaration defines a named function variable without
                requiring variable assignment. Function Declarations occur as
                standalone constructs and cannot be nested within non-function blocks.
                It’s helpful to think of them as siblings of Variable Declarations.
                Just as Variable Declarations must start with “var”, Function
                Declarations must begin with “function”.




                This is the normal way of calling a function in JavaScript, this function can be called before you even declare it as in JavaScript all functions get Hoisted, but if you have 'use strict' this won't Hoist as expected, it's a good way to call all normal functions which are not big in lines and neither are a constructor function.



                Also, if you need more info about how hoisting works in JavaScript, visit the link below:



                https://developer.mozilla.org/en-US/docs/Glossary/Hoisting






                share|improve this answer



















                • 1




                  ...also this way of declaring is a better way to create Constructor functions in JavaScript , may you please elaborate, I'm curious!
                  – Karl Morrison
                  Jun 13 '17 at 12:44












                • One reason is because all built-in Constructor functions in JavaScript created like this function Number() { [native code] } and you shouldn't be confused with built-in ones, also referencing later on in this case is safer and you end up neater code but not using hoisting...
                  – Alireza
                  Jun 13 '17 at 12:56





















                5














                This is just two possible ways of declaring functions, and in the second way, you can use the function before declaration.






                share|improve this answer























                • Please elaborate and provide working code snippets
                  – Jack Giffin
                  May 10 at 21:06



















                4














                new Function() can be used to pass the function's body in a string. And hence this can be used to create dynamic functions. Also passing the script without executing the script.



                var func = new Function("x", "y", "return x*y;");
                function secondFunction(){
                var result;
                result = func(10,20);
                console.log ( result );
                }

                secondFunction()





                share|improve this answer





















                • While this is good and true, how exactly does this alone relate to the quesiton being asked?
                  – Jack Giffin
                  May 10 at 21:06















                1 2
                next


                protected by NullPoiиteя Jun 10 '13 at 5:05



                Thank you for your interest in this question.
                Because it has attracted low-quality or spam answers that had to be removed, posting an answer now requires 10 reputation on this site (the association bonus does not count).



                Would you like to answer one of these unanswered questions instead?














                35 Answers
                35






                active

                oldest

                votes








                35 Answers
                35






                active

                oldest

                votes









                active

                oldest

                votes






                active

                oldest

                votes








                1 2
                next










                4640














                The difference is that functionOne is a function expression and so only defined when that line is reached, whereas functionTwo is a function declaration and is defined as soon as its surrounding function or script is executed (due to hoisting).



                For example, a function expression:






                // TypeError: functionOne is not a function
                functionOne();

                var functionOne = function() {
                console.log("Hello!");
                };





                And, a function declaration:






                // Outputs: "Hello!"
                functionTwo();

                function functionTwo() {
                console.log("Hello!");
                }





                This also means you can't conditionally define functions using function declarations:



                if (test) {
                // Error or misbehavior
                function functionThree() { doSomething(); }
                }


                The above actually defines functionThree irrespective of test's value — unless use strict is in effect, in which case it simply raises an error.






                share|improve this answer



















                • 578




                  @Greg: By the way, the difference isn't only that they are parsed at different times. Essentially, your functionOne is merely a variable that has an anonymous function assigned to it, whereas functionTwo is actually a named function. Call .toString() on both to see the difference. This is significant in some cases where you want to get the name of a function programmatically.
                  – Jason Bunting
                  Aug 5 '11 at 21:18






                • 4




                  @Jason Bunting.. not sure what you're getting at here, .toString() seems to return essentially the same value (the function definition) for both: cl.ly/2a2C2Y1r0J451o0q0B1B
                  – Jon z
                  Sep 9 '11 at 16:29








                • 122




                  There are both different. The first one is a function expression the second one is a function declaration. You can read more on the topic here: javascriptweblog.wordpress.com/2010/07/06/…
                  – Michal Kuklis
                  Nov 14 '11 at 6:03






                • 124




                  @Greg The part of your answer concerning parse time vs. run time is not correct. In JavaScript, function declarations are not defined during parse time, but during run time. The process goes like this: Source code is parsed -> JavaScript program is evaluated -> The global execution context is initialized -> declaration binding instantiation is performed. During this process the function declarations are instantiated (see step 5 of Chapter 10.5).
                  – Šime Vidas
                  Jan 4 '12 at 0:59






                • 98




                  The terminology for this phenomenon is known as hoisting.
                  – Colin Pear
                  Jan 3 '13 at 7:22
















                4640














                The difference is that functionOne is a function expression and so only defined when that line is reached, whereas functionTwo is a function declaration and is defined as soon as its surrounding function or script is executed (due to hoisting).



                For example, a function expression:






                // TypeError: functionOne is not a function
                functionOne();

                var functionOne = function() {
                console.log("Hello!");
                };





                And, a function declaration:






                // Outputs: "Hello!"
                functionTwo();

                function functionTwo() {
                console.log("Hello!");
                }





                This also means you can't conditionally define functions using function declarations:



                if (test) {
                // Error or misbehavior
                function functionThree() { doSomething(); }
                }


                The above actually defines functionThree irrespective of test's value — unless use strict is in effect, in which case it simply raises an error.






                share|improve this answer



















                • 578




                  @Greg: By the way, the difference isn't only that they are parsed at different times. Essentially, your functionOne is merely a variable that has an anonymous function assigned to it, whereas functionTwo is actually a named function. Call .toString() on both to see the difference. This is significant in some cases where you want to get the name of a function programmatically.
                  – Jason Bunting
                  Aug 5 '11 at 21:18






                • 4




                  @Jason Bunting.. not sure what you're getting at here, .toString() seems to return essentially the same value (the function definition) for both: cl.ly/2a2C2Y1r0J451o0q0B1B
                  – Jon z
                  Sep 9 '11 at 16:29








                • 122




                  There are both different. The first one is a function expression the second one is a function declaration. You can read more on the topic here: javascriptweblog.wordpress.com/2010/07/06/…
                  – Michal Kuklis
                  Nov 14 '11 at 6:03






                • 124




                  @Greg The part of your answer concerning parse time vs. run time is not correct. In JavaScript, function declarations are not defined during parse time, but during run time. The process goes like this: Source code is parsed -> JavaScript program is evaluated -> The global execution context is initialized -> declaration binding instantiation is performed. During this process the function declarations are instantiated (see step 5 of Chapter 10.5).
                  – Šime Vidas
                  Jan 4 '12 at 0:59






                • 98




                  The terminology for this phenomenon is known as hoisting.
                  – Colin Pear
                  Jan 3 '13 at 7:22














                4640












                4640








                4640






                The difference is that functionOne is a function expression and so only defined when that line is reached, whereas functionTwo is a function declaration and is defined as soon as its surrounding function or script is executed (due to hoisting).



                For example, a function expression:






                // TypeError: functionOne is not a function
                functionOne();

                var functionOne = function() {
                console.log("Hello!");
                };





                And, a function declaration:






                // Outputs: "Hello!"
                functionTwo();

                function functionTwo() {
                console.log("Hello!");
                }





                This also means you can't conditionally define functions using function declarations:



                if (test) {
                // Error or misbehavior
                function functionThree() { doSomething(); }
                }


                The above actually defines functionThree irrespective of test's value — unless use strict is in effect, in which case it simply raises an error.






                share|improve this answer














                The difference is that functionOne is a function expression and so only defined when that line is reached, whereas functionTwo is a function declaration and is defined as soon as its surrounding function or script is executed (due to hoisting).



                For example, a function expression:






                // TypeError: functionOne is not a function
                functionOne();

                var functionOne = function() {
                console.log("Hello!");
                };





                And, a function declaration:






                // Outputs: "Hello!"
                functionTwo();

                function functionTwo() {
                console.log("Hello!");
                }





                This also means you can't conditionally define functions using function declarations:



                if (test) {
                // Error or misbehavior
                function functionThree() { doSomething(); }
                }


                The above actually defines functionThree irrespective of test's value — unless use strict is in effect, in which case it simply raises an error.






                // TypeError: functionOne is not a function
                functionOne();

                var functionOne = function() {
                console.log("Hello!");
                };





                // TypeError: functionOne is not a function
                functionOne();

                var functionOne = function() {
                console.log("Hello!");
                };





                // Outputs: "Hello!"
                functionTwo();

                function functionTwo() {
                console.log("Hello!");
                }





                // Outputs: "Hello!"
                functionTwo();

                function functionTwo() {
                console.log("Hello!");
                }






                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited May 15 at 9:03









                Sudhanshu Vishnoi

                5271622




                5271622










                answered Dec 3 '08 at 11:37









                Greg

                253k46338321




                253k46338321








                • 578




                  @Greg: By the way, the difference isn't only that they are parsed at different times. Essentially, your functionOne is merely a variable that has an anonymous function assigned to it, whereas functionTwo is actually a named function. Call .toString() on both to see the difference. This is significant in some cases where you want to get the name of a function programmatically.
                  – Jason Bunting
                  Aug 5 '11 at 21:18






                • 4




                  @Jason Bunting.. not sure what you're getting at here, .toString() seems to return essentially the same value (the function definition) for both: cl.ly/2a2C2Y1r0J451o0q0B1B
                  – Jon z
                  Sep 9 '11 at 16:29








                • 122




                  There are both different. The first one is a function expression the second one is a function declaration. You can read more on the topic here: javascriptweblog.wordpress.com/2010/07/06/…
                  – Michal Kuklis
                  Nov 14 '11 at 6:03






                • 124




                  @Greg The part of your answer concerning parse time vs. run time is not correct. In JavaScript, function declarations are not defined during parse time, but during run time. The process goes like this: Source code is parsed -> JavaScript program is evaluated -> The global execution context is initialized -> declaration binding instantiation is performed. During this process the function declarations are instantiated (see step 5 of Chapter 10.5).
                  – Šime Vidas
                  Jan 4 '12 at 0:59






                • 98




                  The terminology for this phenomenon is known as hoisting.
                  – Colin Pear
                  Jan 3 '13 at 7:22














                • 578




                  @Greg: By the way, the difference isn't only that they are parsed at different times. Essentially, your functionOne is merely a variable that has an anonymous function assigned to it, whereas functionTwo is actually a named function. Call .toString() on both to see the difference. This is significant in some cases where you want to get the name of a function programmatically.
                  – Jason Bunting
                  Aug 5 '11 at 21:18






                • 4




                  @Jason Bunting.. not sure what you're getting at here, .toString() seems to return essentially the same value (the function definition) for both: cl.ly/2a2C2Y1r0J451o0q0B1B
                  – Jon z
                  Sep 9 '11 at 16:29








                • 122




                  There are both different. The first one is a function expression the second one is a function declaration. You can read more on the topic here: javascriptweblog.wordpress.com/2010/07/06/…
                  – Michal Kuklis
                  Nov 14 '11 at 6:03






                • 124




                  @Greg The part of your answer concerning parse time vs. run time is not correct. In JavaScript, function declarations are not defined during parse time, but during run time. The process goes like this: Source code is parsed -> JavaScript program is evaluated -> The global execution context is initialized -> declaration binding instantiation is performed. During this process the function declarations are instantiated (see step 5 of Chapter 10.5).
                  – Šime Vidas
                  Jan 4 '12 at 0:59






                • 98




                  The terminology for this phenomenon is known as hoisting.
                  – Colin Pear
                  Jan 3 '13 at 7:22








                578




                578




                @Greg: By the way, the difference isn't only that they are parsed at different times. Essentially, your functionOne is merely a variable that has an anonymous function assigned to it, whereas functionTwo is actually a named function. Call .toString() on both to see the difference. This is significant in some cases where you want to get the name of a function programmatically.
                – Jason Bunting
                Aug 5 '11 at 21:18




                @Greg: By the way, the difference isn't only that they are parsed at different times. Essentially, your functionOne is merely a variable that has an anonymous function assigned to it, whereas functionTwo is actually a named function. Call .toString() on both to see the difference. This is significant in some cases where you want to get the name of a function programmatically.
                – Jason Bunting
                Aug 5 '11 at 21:18




                4




                4




                @Jason Bunting.. not sure what you're getting at here, .toString() seems to return essentially the same value (the function definition) for both: cl.ly/2a2C2Y1r0J451o0q0B1B
                – Jon z
                Sep 9 '11 at 16:29






                @Jason Bunting.. not sure what you're getting at here, .toString() seems to return essentially the same value (the function definition) for both: cl.ly/2a2C2Y1r0J451o0q0B1B
                – Jon z
                Sep 9 '11 at 16:29






                122




                122




                There are both different. The first one is a function expression the second one is a function declaration. You can read more on the topic here: javascriptweblog.wordpress.com/2010/07/06/…
                – Michal Kuklis
                Nov 14 '11 at 6:03




                There are both different. The first one is a function expression the second one is a function declaration. You can read more on the topic here: javascriptweblog.wordpress.com/2010/07/06/…
                – Michal Kuklis
                Nov 14 '11 at 6:03




                124




                124




                @Greg The part of your answer concerning parse time vs. run time is not correct. In JavaScript, function declarations are not defined during parse time, but during run time. The process goes like this: Source code is parsed -> JavaScript program is evaluated -> The global execution context is initialized -> declaration binding instantiation is performed. During this process the function declarations are instantiated (see step 5 of Chapter 10.5).
                – Šime Vidas
                Jan 4 '12 at 0:59




                @Greg The part of your answer concerning parse time vs. run time is not correct. In JavaScript, function declarations are not defined during parse time, but during run time. The process goes like this: Source code is parsed -> JavaScript program is evaluated -> The global execution context is initialized -> declaration binding instantiation is performed. During this process the function declarations are instantiated (see step 5 of Chapter 10.5).
                – Šime Vidas
                Jan 4 '12 at 0:59




                98




                98




                The terminology for this phenomenon is known as hoisting.
                – Colin Pear
                Jan 3 '13 at 7:22




                The terminology for this phenomenon is known as hoisting.
                – Colin Pear
                Jan 3 '13 at 7:22













                1839














                First I want to correct Greg: function abc(){} is scoped too — the name abc is defined in the scope where this definition is encountered. Example:



                function xyz(){
                function abc(){};
                // abc is defined here...
                }
                // ...but not here


                Secondly, it is possible to combine both styles:



                var xyz = function abc(){};


                xyz is going to be defined as usual, abc is undefined in all browsers but Internet Explorer — do not rely on it being defined. But it will be defined inside its body:



                var xyz = function abc(){
                // xyz is visible here
                // abc is visible here
                }
                // xyz is visible here
                // abc is undefined here


                If you want to alias functions on all browsers, use this kind of declaration:



                function abc(){};
                var xyz = abc;


                In this case, both xyz and abc are aliases of the same object:



                console.log(xyz === abc); // prints "true"


                One compelling reason to use the combined style is the "name" attribute of function objects (not supported by Internet Explorer). Basically when you define a function like



                function abc(){};
                console.log(abc.name); // prints "abc"


                its name is automatically assigned. But when you define it like



                var abc = function(){};
                console.log(abc.name); // prints ""


                its name is empty — we created an anonymous function and assigned it to some variable.



                Another good reason to use the combined style is to use a short internal name to refer to itself, while providing a long non-conflicting name for external users:



                // Assume really.long.external.scoped is {}
                really.long.external.scoped.name = function shortcut(n){
                // Let it call itself recursively:
                shortcut(n - 1);
                // ...
                // Let it pass itself as a callback:
                someFunction(shortcut);
                // ...
                }


                In the example above we can do the same with an external name, but it'll be too unwieldy (and slower).



                (Another way to refer to itself is to use arguments.callee, which is still relatively long, and not supported in the strict mode.)



                Deep down, JavaScript treats both statements differently. This is a function declaration:



                function abc(){}


                abc here is defined everywhere in the current scope:



                // We can call it here
                abc(); // Works

                // Yet, it is defined down there.
                function abc(){}

                // We can call it again
                abc(); // Works


                Also, it hoisted through a return statement:



                // We can call it here
                abc(); // Works
                return;
                function abc(){}


                This is a function expression:



                var xyz = function(){};


                xyz here is defined from the point of assignment:



                // We can't call it here
                xyz(); // UNDEFINED!!!

                // Now it is defined
                xyz = function(){}

                // We can call it here
                xyz(); // works


                Function declaration vs. function expression is the real reason why there is a difference demonstrated by Greg.



                Fun fact:



                var xyz = function abc(){};
                console.log(xyz.name); // Prints "abc"


                Personally, I prefer the "function expression" declaration because this way I can control the visibility. When I define the function like



                var abc = function(){};


                I know that I defined the function locally. When I define the function like



                abc = function(){};


                I know that I defined it globally providing that I didn't define abc anywhere in the chain of scopes. This style of definition is resilient even when used inside eval(). While the definition



                function abc(){};


                depends on the context and may leave you guessing where it is actually defined, especially in the case of eval() — the answer is: It depends on the browser.






                share|improve this answer



















                • 65




                  I refer to RoBorg but he is nowhere to be found. Simple: RoBorg === Greg. That's how history can be rewritten in the age of internet. ;-)
                  – Eugene Lazutkin
                  Jul 26 '09 at 2:52






                • 10




                  var xyz = function abc(){}; console.log(xyz === abc); All browsers I've tested (Safari 4, Firefox 3.5.5, Opera 10.10) gives me "Undefined variable: abc".
                  – NVI
                  Dec 3 '09 at 17:43






                • 6




                  Overall I think this post does a good job of explaining the differences and the advantages of utilizing the function declaration. I'll agree to disagree as far as the benefits of utilizing function expression assignments to a variable especially since the "benefit" seems to be an advocation of declaring a global entity... and everyone knows that you shouldn't clutter the global namespace, right? ;-)
                  – natlee75
                  Oct 8 '13 at 16:30






                • 77




                  imo a huge reason to use named function is because debuggers can use the name to help you make sense of your call stack or stack trace. it sucks when you look at the call stack and see "anonymous function" 10 levels deep...
                  – goat
                  Jan 26 '14 at 18:25






                • 2




                  @Antimony A function declaration is not the same thing as a block. This should explain better: stackoverflow.com/questions/17409945/…
                  – Cypher
                  Mar 27 '14 at 23:25
















                1839














                First I want to correct Greg: function abc(){} is scoped too — the name abc is defined in the scope where this definition is encountered. Example:



                function xyz(){
                function abc(){};
                // abc is defined here...
                }
                // ...but not here


                Secondly, it is possible to combine both styles:



                var xyz = function abc(){};


                xyz is going to be defined as usual, abc is undefined in all browsers but Internet Explorer — do not rely on it being defined. But it will be defined inside its body:



                var xyz = function abc(){
                // xyz is visible here
                // abc is visible here
                }
                // xyz is visible here
                // abc is undefined here


                If you want to alias functions on all browsers, use this kind of declaration:



                function abc(){};
                var xyz = abc;


                In this case, both xyz and abc are aliases of the same object:



                console.log(xyz === abc); // prints "true"


                One compelling reason to use the combined style is the "name" attribute of function objects (not supported by Internet Explorer). Basically when you define a function like



                function abc(){};
                console.log(abc.name); // prints "abc"


                its name is automatically assigned. But when you define it like



                var abc = function(){};
                console.log(abc.name); // prints ""


                its name is empty — we created an anonymous function and assigned it to some variable.



                Another good reason to use the combined style is to use a short internal name to refer to itself, while providing a long non-conflicting name for external users:



                // Assume really.long.external.scoped is {}
                really.long.external.scoped.name = function shortcut(n){
                // Let it call itself recursively:
                shortcut(n - 1);
                // ...
                // Let it pass itself as a callback:
                someFunction(shortcut);
                // ...
                }


                In the example above we can do the same with an external name, but it'll be too unwieldy (and slower).



                (Another way to refer to itself is to use arguments.callee, which is still relatively long, and not supported in the strict mode.)



                Deep down, JavaScript treats both statements differently. This is a function declaration:



                function abc(){}


                abc here is defined everywhere in the current scope:



                // We can call it here
                abc(); // Works

                // Yet, it is defined down there.
                function abc(){}

                // We can call it again
                abc(); // Works


                Also, it hoisted through a return statement:



                // We can call it here
                abc(); // Works
                return;
                function abc(){}


                This is a function expression:



                var xyz = function(){};


                xyz here is defined from the point of assignment:



                // We can't call it here
                xyz(); // UNDEFINED!!!

                // Now it is defined
                xyz = function(){}

                // We can call it here
                xyz(); // works


                Function declaration vs. function expression is the real reason why there is a difference demonstrated by Greg.



                Fun fact:



                var xyz = function abc(){};
                console.log(xyz.name); // Prints "abc"


                Personally, I prefer the "function expression" declaration because this way I can control the visibility. When I define the function like



                var abc = function(){};


                I know that I defined the function locally. When I define the function like



                abc = function(){};


                I know that I defined it globally providing that I didn't define abc anywhere in the chain of scopes. This style of definition is resilient even when used inside eval(). While the definition



                function abc(){};


                depends on the context and may leave you guessing where it is actually defined, especially in the case of eval() — the answer is: It depends on the browser.






                share|improve this answer



















                • 65




                  I refer to RoBorg but he is nowhere to be found. Simple: RoBorg === Greg. That's how history can be rewritten in the age of internet. ;-)
                  – Eugene Lazutkin
                  Jul 26 '09 at 2:52






                • 10




                  var xyz = function abc(){}; console.log(xyz === abc); All browsers I've tested (Safari 4, Firefox 3.5.5, Opera 10.10) gives me "Undefined variable: abc".
                  – NVI
                  Dec 3 '09 at 17:43






                • 6




                  Overall I think this post does a good job of explaining the differences and the advantages of utilizing the function declaration. I'll agree to disagree as far as the benefits of utilizing function expression assignments to a variable especially since the "benefit" seems to be an advocation of declaring a global entity... and everyone knows that you shouldn't clutter the global namespace, right? ;-)
                  – natlee75
                  Oct 8 '13 at 16:30






                • 77




                  imo a huge reason to use named function is because debuggers can use the name to help you make sense of your call stack or stack trace. it sucks when you look at the call stack and see "anonymous function" 10 levels deep...
                  – goat
                  Jan 26 '14 at 18:25






                • 2




                  @Antimony A function declaration is not the same thing as a block. This should explain better: stackoverflow.com/questions/17409945/…
                  – Cypher
                  Mar 27 '14 at 23:25














                1839












                1839








                1839






                First I want to correct Greg: function abc(){} is scoped too — the name abc is defined in the scope where this definition is encountered. Example:



                function xyz(){
                function abc(){};
                // abc is defined here...
                }
                // ...but not here


                Secondly, it is possible to combine both styles:



                var xyz = function abc(){};


                xyz is going to be defined as usual, abc is undefined in all browsers but Internet Explorer — do not rely on it being defined. But it will be defined inside its body:



                var xyz = function abc(){
                // xyz is visible here
                // abc is visible here
                }
                // xyz is visible here
                // abc is undefined here


                If you want to alias functions on all browsers, use this kind of declaration:



                function abc(){};
                var xyz = abc;


                In this case, both xyz and abc are aliases of the same object:



                console.log(xyz === abc); // prints "true"


                One compelling reason to use the combined style is the "name" attribute of function objects (not supported by Internet Explorer). Basically when you define a function like



                function abc(){};
                console.log(abc.name); // prints "abc"


                its name is automatically assigned. But when you define it like



                var abc = function(){};
                console.log(abc.name); // prints ""


                its name is empty — we created an anonymous function and assigned it to some variable.



                Another good reason to use the combined style is to use a short internal name to refer to itself, while providing a long non-conflicting name for external users:



                // Assume really.long.external.scoped is {}
                really.long.external.scoped.name = function shortcut(n){
                // Let it call itself recursively:
                shortcut(n - 1);
                // ...
                // Let it pass itself as a callback:
                someFunction(shortcut);
                // ...
                }


                In the example above we can do the same with an external name, but it'll be too unwieldy (and slower).



                (Another way to refer to itself is to use arguments.callee, which is still relatively long, and not supported in the strict mode.)



                Deep down, JavaScript treats both statements differently. This is a function declaration:



                function abc(){}


                abc here is defined everywhere in the current scope:



                // We can call it here
                abc(); // Works

                // Yet, it is defined down there.
                function abc(){}

                // We can call it again
                abc(); // Works


                Also, it hoisted through a return statement:



                // We can call it here
                abc(); // Works
                return;
                function abc(){}


                This is a function expression:



                var xyz = function(){};


                xyz here is defined from the point of assignment:



                // We can't call it here
                xyz(); // UNDEFINED!!!

                // Now it is defined
                xyz = function(){}

                // We can call it here
                xyz(); // works


                Function declaration vs. function expression is the real reason why there is a difference demonstrated by Greg.



                Fun fact:



                var xyz = function abc(){};
                console.log(xyz.name); // Prints "abc"


                Personally, I prefer the "function expression" declaration because this way I can control the visibility. When I define the function like



                var abc = function(){};


                I know that I defined the function locally. When I define the function like



                abc = function(){};


                I know that I defined it globally providing that I didn't define abc anywhere in the chain of scopes. This style of definition is resilient even when used inside eval(). While the definition



                function abc(){};


                depends on the context and may leave you guessing where it is actually defined, especially in the case of eval() — the answer is: It depends on the browser.






                share|improve this answer














                First I want to correct Greg: function abc(){} is scoped too — the name abc is defined in the scope where this definition is encountered. Example:



                function xyz(){
                function abc(){};
                // abc is defined here...
                }
                // ...but not here


                Secondly, it is possible to combine both styles:



                var xyz = function abc(){};


                xyz is going to be defined as usual, abc is undefined in all browsers but Internet Explorer — do not rely on it being defined. But it will be defined inside its body:



                var xyz = function abc(){
                // xyz is visible here
                // abc is visible here
                }
                // xyz is visible here
                // abc is undefined here


                If you want to alias functions on all browsers, use this kind of declaration:



                function abc(){};
                var xyz = abc;


                In this case, both xyz and abc are aliases of the same object:



                console.log(xyz === abc); // prints "true"


                One compelling reason to use the combined style is the "name" attribute of function objects (not supported by Internet Explorer). Basically when you define a function like



                function abc(){};
                console.log(abc.name); // prints "abc"


                its name is automatically assigned. But when you define it like



                var abc = function(){};
                console.log(abc.name); // prints ""


                its name is empty — we created an anonymous function and assigned it to some variable.



                Another good reason to use the combined style is to use a short internal name to refer to itself, while providing a long non-conflicting name for external users:



                // Assume really.long.external.scoped is {}
                really.long.external.scoped.name = function shortcut(n){
                // Let it call itself recursively:
                shortcut(n - 1);
                // ...
                // Let it pass itself as a callback:
                someFunction(shortcut);
                // ...
                }


                In the example above we can do the same with an external name, but it'll be too unwieldy (and slower).



                (Another way to refer to itself is to use arguments.callee, which is still relatively long, and not supported in the strict mode.)



                Deep down, JavaScript treats both statements differently. This is a function declaration:



                function abc(){}


                abc here is defined everywhere in the current scope:



                // We can call it here
                abc(); // Works

                // Yet, it is defined down there.
                function abc(){}

                // We can call it again
                abc(); // Works


                Also, it hoisted through a return statement:



                // We can call it here
                abc(); // Works
                return;
                function abc(){}


                This is a function expression:



                var xyz = function(){};


                xyz here is defined from the point of assignment:



                // We can't call it here
                xyz(); // UNDEFINED!!!

                // Now it is defined
                xyz = function(){}

                // We can call it here
                xyz(); // works


                Function declaration vs. function expression is the real reason why there is a difference demonstrated by Greg.



                Fun fact:



                var xyz = function abc(){};
                console.log(xyz.name); // Prints "abc"


                Personally, I prefer the "function expression" declaration because this way I can control the visibility. When I define the function like



                var abc = function(){};


                I know that I defined the function locally. When I define the function like



                abc = function(){};


                I know that I defined it globally providing that I didn't define abc anywhere in the chain of scopes. This style of definition is resilient even when used inside eval(). While the definition



                function abc(){};


                depends on the context and may leave you guessing where it is actually defined, especially in the case of eval() — the answer is: It depends on the browser.







                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited Oct 10 '16 at 20:38









                Merlin

                3,81322143




                3,81322143










                answered Dec 3 '08 at 17:43









                Eugene Lazutkin

                38.6k84453




                38.6k84453








                • 65




                  I refer to RoBorg but he is nowhere to be found. Simple: RoBorg === Greg. That's how history can be rewritten in the age of internet. ;-)
                  – Eugene Lazutkin
                  Jul 26 '09 at 2:52






                • 10




                  var xyz = function abc(){}; console.log(xyz === abc); All browsers I've tested (Safari 4, Firefox 3.5.5, Opera 10.10) gives me "Undefined variable: abc".
                  – NVI
                  Dec 3 '09 at 17:43






                • 6




                  Overall I think this post does a good job of explaining the differences and the advantages of utilizing the function declaration. I'll agree to disagree as far as the benefits of utilizing function expression assignments to a variable especially since the "benefit" seems to be an advocation of declaring a global entity... and everyone knows that you shouldn't clutter the global namespace, right? ;-)
                  – natlee75
                  Oct 8 '13 at 16:30






                • 77




                  imo a huge reason to use named function is because debuggers can use the name to help you make sense of your call stack or stack trace. it sucks when you look at the call stack and see "anonymous function" 10 levels deep...
                  – goat
                  Jan 26 '14 at 18:25






                • 2




                  @Antimony A function declaration is not the same thing as a block. This should explain better: stackoverflow.com/questions/17409945/…
                  – Cypher
                  Mar 27 '14 at 23:25














                • 65




                  I refer to RoBorg but he is nowhere to be found. Simple: RoBorg === Greg. That's how history can be rewritten in the age of internet. ;-)
                  – Eugene Lazutkin
                  Jul 26 '09 at 2:52






                • 10




                  var xyz = function abc(){}; console.log(xyz === abc); All browsers I've tested (Safari 4, Firefox 3.5.5, Opera 10.10) gives me "Undefined variable: abc".
                  – NVI
                  Dec 3 '09 at 17:43






                • 6




                  Overall I think this post does a good job of explaining the differences and the advantages of utilizing the function declaration. I'll agree to disagree as far as the benefits of utilizing function expression assignments to a variable especially since the "benefit" seems to be an advocation of declaring a global entity... and everyone knows that you shouldn't clutter the global namespace, right? ;-)
                  – natlee75
                  Oct 8 '13 at 16:30






                • 77




                  imo a huge reason to use named function is because debuggers can use the name to help you make sense of your call stack or stack trace. it sucks when you look at the call stack and see "anonymous function" 10 levels deep...
                  – goat
                  Jan 26 '14 at 18:25






                • 2




                  @Antimony A function declaration is not the same thing as a block. This should explain better: stackoverflow.com/questions/17409945/…
                  – Cypher
                  Mar 27 '14 at 23:25








                65




                65




                I refer to RoBorg but he is nowhere to be found. Simple: RoBorg === Greg. That's how history can be rewritten in the age of internet. ;-)
                – Eugene Lazutkin
                Jul 26 '09 at 2:52




                I refer to RoBorg but he is nowhere to be found. Simple: RoBorg === Greg. That's how history can be rewritten in the age of internet. ;-)
                – Eugene Lazutkin
                Jul 26 '09 at 2:52




                10




                10




                var xyz = function abc(){}; console.log(xyz === abc); All browsers I've tested (Safari 4, Firefox 3.5.5, Opera 10.10) gives me "Undefined variable: abc".
                – NVI
                Dec 3 '09 at 17:43




                var xyz = function abc(){}; console.log(xyz === abc); All browsers I've tested (Safari 4, Firefox 3.5.5, Opera 10.10) gives me "Undefined variable: abc".
                – NVI
                Dec 3 '09 at 17:43




                6




                6




                Overall I think this post does a good job of explaining the differences and the advantages of utilizing the function declaration. I'll agree to disagree as far as the benefits of utilizing function expression assignments to a variable especially since the "benefit" seems to be an advocation of declaring a global entity... and everyone knows that you shouldn't clutter the global namespace, right? ;-)
                – natlee75
                Oct 8 '13 at 16:30




                Overall I think this post does a good job of explaining the differences and the advantages of utilizing the function declaration. I'll agree to disagree as far as the benefits of utilizing function expression assignments to a variable especially since the "benefit" seems to be an advocation of declaring a global entity... and everyone knows that you shouldn't clutter the global namespace, right? ;-)
                – natlee75
                Oct 8 '13 at 16:30




                77




                77




                imo a huge reason to use named function is because debuggers can use the name to help you make sense of your call stack or stack trace. it sucks when you look at the call stack and see "anonymous function" 10 levels deep...
                – goat
                Jan 26 '14 at 18:25




                imo a huge reason to use named function is because debuggers can use the name to help you make sense of your call stack or stack trace. it sucks when you look at the call stack and see "anonymous function" 10 levels deep...
                – goat
                Jan 26 '14 at 18:25




                2




                2




                @Antimony A function declaration is not the same thing as a block. This should explain better: stackoverflow.com/questions/17409945/…
                – Cypher
                Mar 27 '14 at 23:25




                @Antimony A function declaration is not the same thing as a block. This should explain better: stackoverflow.com/questions/17409945/…
                – Cypher
                Mar 27 '14 at 23:25











                568





                +200









                Here's the rundown on the standard forms that create functions: (Originally written for another question, but adapted after being moved into the canonical question.)



                Terms:





                • ES5: ECMAScript 5th edition, 2009


                • ES2015: ECMAScript 2015 (also known as "ES6")


                The quick list:




                • Function Declaration


                • "Anonymous" function Expression (which despite the term, sometimes create functions with names)


                • Named function Expression


                • Accessor Function Initializer (ES5+)


                • Arrow Function Expression (ES2015+) (which, like anonymous function expressions, don't involve an explicit name, and yet can create functions with names)


                • Method Declaration in Object Initializer (ES2015+)


                • Constructor and Method Declarations in class (ES2015+)



                Function Declaration



                The first form is a function declaration, which looks like this:



                function x() {
                console.log('x');
                }


                A function declaration is a declaration; it's not a statement or expression. As such, you don't follow it with a ; (although doing so is harmless).



                A function declaration is processed when execution enters the context in which it appears, before any step-by-step code is executed. The function it creates is given a proper name (x in the example above), and that name is put in the scope in which the declaration appears.



                Because it's processed before any step-by-step code in the same context, you can do things like this:



                x(); // Works even though it's above the declaration
                function x() {
                console.log('x');
                }


                Until ES2015, the spec didn't cover what a JavaScript engine should do if you put a function declaration inside a control structure like try, if, switch, while, etc., like this:



                if (someCondition) {
                function foo() { // <===== HERE THERE
                } // <===== BE DRAGONS
                }


                And since they're processed before step-by-step code is run, it's tricky to know what to do when they're in a control structure.



                Although doing this wasn't specified until ES2015, it was an allowable extension to support function declarations in blocks. Unfortunately (and inevitably), different engines did different things.



                As of ES2015, the specification says what to do. In fact, it gives three separate things to do:




                1. If in loose mode not on a web browser, the JavaScript engine is supposed to do one thing

                2. If in loose mode on a web browser, the JavaScript engine is supposed to do something else

                3. If in strict mode (browser or not), the JavaScript engine is supposed to do yet another thing


                The rules for the loose modes are tricky, but in strict mode, function declarations in blocks are easy: They're local to the block (they have block scope, which is also new in ES2015), and they're hoisted to the top of the block. So:



                "use strict";
                if (someCondition) {
                foo(); // Works just fine
                function foo() {
                }
                }
                console.log(typeof foo); // "undefined" (`foo` is not in scope here
                // because it's not in the same block)


                "Anonymous" function Expression



                The second common form is called an anonymous function expression:



                var y = function () {
                console.log('y');
                };


                Like all expressions, it's evaluated when it's reached in the step-by-step execution of the code.



                In ES5, the function this creates has no name (it's anonymous). In ES2015, the function is assigned a name if possible by inferring it from context. In the example above, the name would be y. Something similar is done when the function is the value of a property initializer. (For details on when this happens and the rules, search for SetFunctionName in the the specification — it appears all over the place.)



                Named function Expression



                The third form is a named function expression ("NFE"):



                var z = function w() {
                console.log('zw')
                };


                The function this creates has a proper name (w in this case). Like all expressions, this is evaluated when it's reached in the step-by-step execution of the code. The name of the function is not added to the scope in which the expression appears; the name is in scope within the function itself:



                var z = function w() {
                console.log(typeof w); // "function"
                };
                console.log(typeof w); // "undefined"


                Note that NFEs have frequently been a source of bugs for JavaScript implementations. IE8 and earlier, for instance, handle NFEs completely incorrectly, creating two different functions at two different times. Early versions of Safari had issues as well. The good news is that current versions of browsers (IE9 and up, current Safari) don't have those issues any more. (But as of this writing, sadly, IE8 remains in widespread use, and so using NFEs with code for the web in general is still problematic.)



                Accessor Function Initializer (ES5+)



                Sometimes functions can sneak in largely unnoticed; that's the case with accessor functions. Here's an example:



                var obj = {
                value: 0,
                get f() {
                return this.value;
                },
                set f(v) {
                this.value = v;
                }
                };
                console.log(obj.f); // 0
                console.log(typeof obj.f); // "number"


                Note that when I used the function, I didn't use ()! That's because it's an accessor function for a property. We get and set the property in the normal way, but behind the scenes, the function is called.



                You can also create accessor functions with Object.defineProperty, Object.defineProperties, and the lesser-known second argument to Object.create.



                Arrow Function Expression (ES2015+)



                ES2015 brings us the arrow function. Here's one example:



                var a = [1, 2, 3];
                var b = a.map(n => n * 2);
                console.log(b.join(", ")); // 2, 4, 6


                See that n => n * 2 thing hiding in the map() call? That's a function.



                A couple of things about arrow functions:




                1. They don't have their own this. Instead, they close over the this of the context where they're defined. (They also close over arguments and, where relevant, super.) This means that the this within them is the same as the this where they're created, and cannot be changed.


                2. As you'll have noticed with the above, you don't use the keyword function; instead, you use =>.



                The n => n * 2 example above is one form of them. If you have multiple arguments to pass the function, you use parens:



                var a = [1, 2, 3];
                var b = a.map((n, i) => n * i);
                console.log(b.join(", ")); // 0, 2, 6


                (Remember that Array#map passes the entry as the first argument, and the index as the second.)



                In both cases, the body of the function is just an expression; the function's return value will automatically be the result of that expression (you don't use an explicit return).



                If you're doing more than just a single expression, use {} and an explicit return (if you need to return a value), as normal:



                var a = [
                {first: "Joe", last: "Bloggs"},
                {first: "Albert", last: "Bloggs"},
                {first: "Mary", last: "Albright"}
                ];
                a = a.sort((a, b) => {
                var rv = a.last.localeCompare(b.last);
                if (rv === 0) {
                rv = a.first.localeCompare(b.first);
                }
                return rv;
                });
                console.log(JSON.stringify(a));


                The version without { ... } is called an arrow function with an expression body or concise body. (Also: A concise arrow function.) The one with { ... } defining the body is an arrow function with a function body. (Also: A verbose arrow function.)



                Method Declaration in Object Initializer (ES2015+)



                ES2015 allows a shorter form of declaring a property that references a function; it looks like this:



                var o = {
                foo() {
                }
                };


                the equivalent in ES5 and earlier would be:



                var o = {
                foo: function foo() {
                }
                };


                Constructor and Method Declarations in class (ES2015+)



                ES2015 brings us class syntax, including declared constructors and methods:



                class Person {
                constructor(firstName, lastName) {
                this.firstName = firstName;
                this.lastName = lastName;
                }

                getFullName() {
                return this.firstName + " " + this.lastName;
                }
                }


                There are two function declarations above: One for the constructor, which gets the name Person, and one for getFullName, which is a function assigned to Person.prototype.






                share|improve this answer



















                • 3




                  then the name w is simply ignored ?
                  – BiAiB
                  Mar 4 '14 at 13:37






                • 8




                  @PellePenna: Function names are useful for lots of things. The two biggies in my view are recursion, and the name of the function being shown in call stacks, exception traces, and such.
                  – T.J. Crowder
                  Mar 4 '14 at 13:42






                • 10




                  This should now be the accepted answer. It's much more recent than the one above.
                  – Chaim Eliyah
                  Oct 2 '15 at 16:15






                • 4




                  @ChaimEliyah - "Accepting doesn't mean it's the best answer, it just means that it worked for the person who asked." source
                  – ScrapCode
                  Feb 10 '16 at 10:19






                • 6




                  @A.R.: Quite true. Amusingly, though, right above that it says "The best answers show up first so that they are always easy to find." Since the accepted answer shows up first even over higher-voted answers, the tour might be somewhat self-contradicting. ;-) Also a bit inaccurate, if we determine "best" by votes (which isn't reliable, it's just what we've got), "best" answers only show up first if you're using the "Votes" tab -- otherwise, the answers that are first are the active ones, or the oldest ones.
                  – T.J. Crowder
                  Feb 10 '16 at 10:32
















                568





                +200









                Here's the rundown on the standard forms that create functions: (Originally written for another question, but adapted after being moved into the canonical question.)



                Terms:





                • ES5: ECMAScript 5th edition, 2009


                • ES2015: ECMAScript 2015 (also known as "ES6")


                The quick list:




                • Function Declaration


                • "Anonymous" function Expression (which despite the term, sometimes create functions with names)


                • Named function Expression


                • Accessor Function Initializer (ES5+)


                • Arrow Function Expression (ES2015+) (which, like anonymous function expressions, don't involve an explicit name, and yet can create functions with names)


                • Method Declaration in Object Initializer (ES2015+)


                • Constructor and Method Declarations in class (ES2015+)



                Function Declaration



                The first form is a function declaration, which looks like this:



                function x() {
                console.log('x');
                }


                A function declaration is a declaration; it's not a statement or expression. As such, you don't follow it with a ; (although doing so is harmless).



                A function declaration is processed when execution enters the context in which it appears, before any step-by-step code is executed. The function it creates is given a proper name (x in the example above), and that name is put in the scope in which the declaration appears.



                Because it's processed before any step-by-step code in the same context, you can do things like this:



                x(); // Works even though it's above the declaration
                function x() {
                console.log('x');
                }


                Until ES2015, the spec didn't cover what a JavaScript engine should do if you put a function declaration inside a control structure like try, if, switch, while, etc., like this:



                if (someCondition) {
                function foo() { // <===== HERE THERE
                } // <===== BE DRAGONS
                }


                And since they're processed before step-by-step code is run, it's tricky to know what to do when they're in a control structure.



                Although doing this wasn't specified until ES2015, it was an allowable extension to support function declarations in blocks. Unfortunately (and inevitably), different engines did different things.



                As of ES2015, the specification says what to do. In fact, it gives three separate things to do:




                1. If in loose mode not on a web browser, the JavaScript engine is supposed to do one thing

                2. If in loose mode on a web browser, the JavaScript engine is supposed to do something else

                3. If in strict mode (browser or not), the JavaScript engine is supposed to do yet another thing


                The rules for the loose modes are tricky, but in strict mode, function declarations in blocks are easy: They're local to the block (they have block scope, which is also new in ES2015), and they're hoisted to the top of the block. So:



                "use strict";
                if (someCondition) {
                foo(); // Works just fine
                function foo() {
                }
                }
                console.log(typeof foo); // "undefined" (`foo` is not in scope here
                // because it's not in the same block)


                "Anonymous" function Expression



                The second common form is called an anonymous function expression:



                var y = function () {
                console.log('y');
                };


                Like all expressions, it's evaluated when it's reached in the step-by-step execution of the code.



                In ES5, the function this creates has no name (it's anonymous). In ES2015, the function is assigned a name if possible by inferring it from context. In the example above, the name would be y. Something similar is done when the function is the value of a property initializer. (For details on when this happens and the rules, search for SetFunctionName in the the specification — it appears all over the place.)



                Named function Expression



                The third form is a named function expression ("NFE"):



                var z = function w() {
                console.log('zw')
                };


                The function this creates has a proper name (w in this case). Like all expressions, this is evaluated when it's reached in the step-by-step execution of the code. The name of the function is not added to the scope in which the expression appears; the name is in scope within the function itself:



                var z = function w() {
                console.log(typeof w); // "function"
                };
                console.log(typeof w); // "undefined"


                Note that NFEs have frequently been a source of bugs for JavaScript implementations. IE8 and earlier, for instance, handle NFEs completely incorrectly, creating two different functions at two different times. Early versions of Safari had issues as well. The good news is that current versions of browsers (IE9 and up, current Safari) don't have those issues any more. (But as of this writing, sadly, IE8 remains in widespread use, and so using NFEs with code for the web in general is still problematic.)



                Accessor Function Initializer (ES5+)



                Sometimes functions can sneak in largely unnoticed; that's the case with accessor functions. Here's an example:



                var obj = {
                value: 0,
                get f() {
                return this.value;
                },
                set f(v) {
                this.value = v;
                }
                };
                console.log(obj.f); // 0
                console.log(typeof obj.f); // "number"


                Note that when I used the function, I didn't use ()! That's because it's an accessor function for a property. We get and set the property in the normal way, but behind the scenes, the function is called.



                You can also create accessor functions with Object.defineProperty, Object.defineProperties, and the lesser-known second argument to Object.create.



                Arrow Function Expression (ES2015+)



                ES2015 brings us the arrow function. Here's one example:



                var a = [1, 2, 3];
                var b = a.map(n => n * 2);
                console.log(b.join(", ")); // 2, 4, 6


                See that n => n * 2 thing hiding in the map() call? That's a function.



                A couple of things about arrow functions:




                1. They don't have their own this. Instead, they close over the this of the context where they're defined. (They also close over arguments and, where relevant, super.) This means that the this within them is the same as the this where they're created, and cannot be changed.


                2. As you'll have noticed with the above, you don't use the keyword function; instead, you use =>.



                The n => n * 2 example above is one form of them. If you have multiple arguments to pass the function, you use parens:



                var a = [1, 2, 3];
                var b = a.map((n, i) => n * i);
                console.log(b.join(", ")); // 0, 2, 6


                (Remember that Array#map passes the entry as the first argument, and the index as the second.)



                In both cases, the body of the function is just an expression; the function's return value will automatically be the result of that expression (you don't use an explicit return).



                If you're doing more than just a single expression, use {} and an explicit return (if you need to return a value), as normal:



                var a = [
                {first: "Joe", last: "Bloggs"},
                {first: "Albert", last: "Bloggs"},
                {first: "Mary", last: "Albright"}
                ];
                a = a.sort((a, b) => {
                var rv = a.last.localeCompare(b.last);
                if (rv === 0) {
                rv = a.first.localeCompare(b.first);
                }
                return rv;
                });
                console.log(JSON.stringify(a));


                The version without { ... } is called an arrow function with an expression body or concise body. (Also: A concise arrow function.) The one with { ... } defining the body is an arrow function with a function body. (Also: A verbose arrow function.)



                Method Declaration in Object Initializer (ES2015+)



                ES2015 allows a shorter form of declaring a property that references a function; it looks like this:



                var o = {
                foo() {
                }
                };


                the equivalent in ES5 and earlier would be:



                var o = {
                foo: function foo() {
                }
                };


                Constructor and Method Declarations in class (ES2015+)



                ES2015 brings us class syntax, including declared constructors and methods:



                class Person {
                constructor(firstName, lastName) {
                this.firstName = firstName;
                this.lastName = lastName;
                }

                getFullName() {
                return this.firstName + " " + this.lastName;
                }
                }


                There are two function declarations above: One for the constructor, which gets the name Person, and one for getFullName, which is a function assigned to Person.prototype.






                share|improve this answer



















                • 3




                  then the name w is simply ignored ?
                  – BiAiB
                  Mar 4 '14 at 13:37






                • 8




                  @PellePenna: Function names are useful for lots of things. The two biggies in my view are recursion, and the name of the function being shown in call stacks, exception traces, and such.
                  – T.J. Crowder
                  Mar 4 '14 at 13:42






                • 10




                  This should now be the accepted answer. It's much more recent than the one above.
                  – Chaim Eliyah
                  Oct 2 '15 at 16:15






                • 4




                  @ChaimEliyah - "Accepting doesn't mean it's the best answer, it just means that it worked for the person who asked." source
                  – ScrapCode
                  Feb 10 '16 at 10:19






                • 6




                  @A.R.: Quite true. Amusingly, though, right above that it says "The best answers show up first so that they are always easy to find." Since the accepted answer shows up first even over higher-voted answers, the tour might be somewhat self-contradicting. ;-) Also a bit inaccurate, if we determine "best" by votes (which isn't reliable, it's just what we've got), "best" answers only show up first if you're using the "Votes" tab -- otherwise, the answers that are first are the active ones, or the oldest ones.
                  – T.J. Crowder
                  Feb 10 '16 at 10:32














                568





                +200







                568





                +200



                568




                +200




                Here's the rundown on the standard forms that create functions: (Originally written for another question, but adapted after being moved into the canonical question.)



                Terms:





                • ES5: ECMAScript 5th edition, 2009


                • ES2015: ECMAScript 2015 (also known as "ES6")


                The quick list:




                • Function Declaration


                • "Anonymous" function Expression (which despite the term, sometimes create functions with names)


                • Named function Expression


                • Accessor Function Initializer (ES5+)


                • Arrow Function Expression (ES2015+) (which, like anonymous function expressions, don't involve an explicit name, and yet can create functions with names)


                • Method Declaration in Object Initializer (ES2015+)


                • Constructor and Method Declarations in class (ES2015+)



                Function Declaration



                The first form is a function declaration, which looks like this:



                function x() {
                console.log('x');
                }


                A function declaration is a declaration; it's not a statement or expression. As such, you don't follow it with a ; (although doing so is harmless).



                A function declaration is processed when execution enters the context in which it appears, before any step-by-step code is executed. The function it creates is given a proper name (x in the example above), and that name is put in the scope in which the declaration appears.



                Because it's processed before any step-by-step code in the same context, you can do things like this:



                x(); // Works even though it's above the declaration
                function x() {
                console.log('x');
                }


                Until ES2015, the spec didn't cover what a JavaScript engine should do if you put a function declaration inside a control structure like try, if, switch, while, etc., like this:



                if (someCondition) {
                function foo() { // <===== HERE THERE
                } // <===== BE DRAGONS
                }


                And since they're processed before step-by-step code is run, it's tricky to know what to do when they're in a control structure.



                Although doing this wasn't specified until ES2015, it was an allowable extension to support function declarations in blocks. Unfortunately (and inevitably), different engines did different things.



                As of ES2015, the specification says what to do. In fact, it gives three separate things to do:




                1. If in loose mode not on a web browser, the JavaScript engine is supposed to do one thing

                2. If in loose mode on a web browser, the JavaScript engine is supposed to do something else

                3. If in strict mode (browser or not), the JavaScript engine is supposed to do yet another thing


                The rules for the loose modes are tricky, but in strict mode, function declarations in blocks are easy: They're local to the block (they have block scope, which is also new in ES2015), and they're hoisted to the top of the block. So:



                "use strict";
                if (someCondition) {
                foo(); // Works just fine
                function foo() {
                }
                }
                console.log(typeof foo); // "undefined" (`foo` is not in scope here
                // because it's not in the same block)


                "Anonymous" function Expression



                The second common form is called an anonymous function expression:



                var y = function () {
                console.log('y');
                };


                Like all expressions, it's evaluated when it's reached in the step-by-step execution of the code.



                In ES5, the function this creates has no name (it's anonymous). In ES2015, the function is assigned a name if possible by inferring it from context. In the example above, the name would be y. Something similar is done when the function is the value of a property initializer. (For details on when this happens and the rules, search for SetFunctionName in the the specification — it appears all over the place.)



                Named function Expression



                The third form is a named function expression ("NFE"):



                var z = function w() {
                console.log('zw')
                };


                The function this creates has a proper name (w in this case). Like all expressions, this is evaluated when it's reached in the step-by-step execution of the code. The name of the function is not added to the scope in which the expression appears; the name is in scope within the function itself:



                var z = function w() {
                console.log(typeof w); // "function"
                };
                console.log(typeof w); // "undefined"


                Note that NFEs have frequently been a source of bugs for JavaScript implementations. IE8 and earlier, for instance, handle NFEs completely incorrectly, creating two different functions at two different times. Early versions of Safari had issues as well. The good news is that current versions of browsers (IE9 and up, current Safari) don't have those issues any more. (But as of this writing, sadly, IE8 remains in widespread use, and so using NFEs with code for the web in general is still problematic.)



                Accessor Function Initializer (ES5+)



                Sometimes functions can sneak in largely unnoticed; that's the case with accessor functions. Here's an example:



                var obj = {
                value: 0,
                get f() {
                return this.value;
                },
                set f(v) {
                this.value = v;
                }
                };
                console.log(obj.f); // 0
                console.log(typeof obj.f); // "number"


                Note that when I used the function, I didn't use ()! That's because it's an accessor function for a property. We get and set the property in the normal way, but behind the scenes, the function is called.



                You can also create accessor functions with Object.defineProperty, Object.defineProperties, and the lesser-known second argument to Object.create.



                Arrow Function Expression (ES2015+)



                ES2015 brings us the arrow function. Here's one example:



                var a = [1, 2, 3];
                var b = a.map(n => n * 2);
                console.log(b.join(", ")); // 2, 4, 6


                See that n => n * 2 thing hiding in the map() call? That's a function.



                A couple of things about arrow functions:




                1. They don't have their own this. Instead, they close over the this of the context where they're defined. (They also close over arguments and, where relevant, super.) This means that the this within them is the same as the this where they're created, and cannot be changed.


                2. As you'll have noticed with the above, you don't use the keyword function; instead, you use =>.



                The n => n * 2 example above is one form of them. If you have multiple arguments to pass the function, you use parens:



                var a = [1, 2, 3];
                var b = a.map((n, i) => n * i);
                console.log(b.join(", ")); // 0, 2, 6


                (Remember that Array#map passes the entry as the first argument, and the index as the second.)



                In both cases, the body of the function is just an expression; the function's return value will automatically be the result of that expression (you don't use an explicit return).



                If you're doing more than just a single expression, use {} and an explicit return (if you need to return a value), as normal:



                var a = [
                {first: "Joe", last: "Bloggs"},
                {first: "Albert", last: "Bloggs"},
                {first: "Mary", last: "Albright"}
                ];
                a = a.sort((a, b) => {
                var rv = a.last.localeCompare(b.last);
                if (rv === 0) {
                rv = a.first.localeCompare(b.first);
                }
                return rv;
                });
                console.log(JSON.stringify(a));


                The version without { ... } is called an arrow function with an expression body or concise body. (Also: A concise arrow function.) The one with { ... } defining the body is an arrow function with a function body. (Also: A verbose arrow function.)



                Method Declaration in Object Initializer (ES2015+)



                ES2015 allows a shorter form of declaring a property that references a function; it looks like this:



                var o = {
                foo() {
                }
                };


                the equivalent in ES5 and earlier would be:



                var o = {
                foo: function foo() {
                }
                };


                Constructor and Method Declarations in class (ES2015+)



                ES2015 brings us class syntax, including declared constructors and methods:



                class Person {
                constructor(firstName, lastName) {
                this.firstName = firstName;
                this.lastName = lastName;
                }

                getFullName() {
                return this.firstName + " " + this.lastName;
                }
                }


                There are two function declarations above: One for the constructor, which gets the name Person, and one for getFullName, which is a function assigned to Person.prototype.






                share|improve this answer














                Here's the rundown on the standard forms that create functions: (Originally written for another question, but adapted after being moved into the canonical question.)



                Terms:





                • ES5: ECMAScript 5th edition, 2009


                • ES2015: ECMAScript 2015 (also known as "ES6")


                The quick list:




                • Function Declaration


                • "Anonymous" function Expression (which despite the term, sometimes create functions with names)


                • Named function Expression


                • Accessor Function Initializer (ES5+)


                • Arrow Function Expression (ES2015+) (which, like anonymous function expressions, don't involve an explicit name, and yet can create functions with names)


                • Method Declaration in Object Initializer (ES2015+)


                • Constructor and Method Declarations in class (ES2015+)



                Function Declaration



                The first form is a function declaration, which looks like this:



                function x() {
                console.log('x');
                }


                A function declaration is a declaration; it's not a statement or expression. As such, you don't follow it with a ; (although doing so is harmless).



                A function declaration is processed when execution enters the context in which it appears, before any step-by-step code is executed. The function it creates is given a proper name (x in the example above), and that name is put in the scope in which the declaration appears.



                Because it's processed before any step-by-step code in the same context, you can do things like this:



                x(); // Works even though it's above the declaration
                function x() {
                console.log('x');
                }


                Until ES2015, the spec didn't cover what a JavaScript engine should do if you put a function declaration inside a control structure like try, if, switch, while, etc., like this:



                if (someCondition) {
                function foo() { // <===== HERE THERE
                } // <===== BE DRAGONS
                }


                And since they're processed before step-by-step code is run, it's tricky to know what to do when they're in a control structure.



                Although doing this wasn't specified until ES2015, it was an allowable extension to support function declarations in blocks. Unfortunately (and inevitably), different engines did different things.



                As of ES2015, the specification says what to do. In fact, it gives three separate things to do:




                1. If in loose mode not on a web browser, the JavaScript engine is supposed to do one thing

                2. If in loose mode on a web browser, the JavaScript engine is supposed to do something else

                3. If in strict mode (browser or not), the JavaScript engine is supposed to do yet another thing


                The rules for the loose modes are tricky, but in strict mode, function declarations in blocks are easy: They're local to the block (they have block scope, which is also new in ES2015), and they're hoisted to the top of the block. So:



                "use strict";
                if (someCondition) {
                foo(); // Works just fine
                function foo() {
                }
                }
                console.log(typeof foo); // "undefined" (`foo` is not in scope here
                // because it's not in the same block)


                "Anonymous" function Expression



                The second common form is called an anonymous function expression:



                var y = function () {
                console.log('y');
                };


                Like all expressions, it's evaluated when it's reached in the step-by-step execution of the code.



                In ES5, the function this creates has no name (it's anonymous). In ES2015, the function is assigned a name if possible by inferring it from context. In the example above, the name would be y. Something similar is done when the function is the value of a property initializer. (For details on when this happens and the rules, search for SetFunctionName in the the specification — it appears all over the place.)



                Named function Expression



                The third form is a named function expression ("NFE"):



                var z = function w() {
                console.log('zw')
                };


                The function this creates has a proper name (w in this case). Like all expressions, this is evaluated when it's reached in the step-by-step execution of the code. The name of the function is not added to the scope in which the expression appears; the name is in scope within the function itself:



                var z = function w() {
                console.log(typeof w); // "function"
                };
                console.log(typeof w); // "undefined"


                Note that NFEs have frequently been a source of bugs for JavaScript implementations. IE8 and earlier, for instance, handle NFEs completely incorrectly, creating two different functions at two different times. Early versions of Safari had issues as well. The good news is that current versions of browsers (IE9 and up, current Safari) don't have those issues any more. (But as of this writing, sadly, IE8 remains in widespread use, and so using NFEs with code for the web in general is still problematic.)



                Accessor Function Initializer (ES5+)



                Sometimes functions can sneak in largely unnoticed; that's the case with accessor functions. Here's an example:



                var obj = {
                value: 0,
                get f() {
                return this.value;
                },
                set f(v) {
                this.value = v;
                }
                };
                console.log(obj.f); // 0
                console.log(typeof obj.f); // "number"


                Note that when I used the function, I didn't use ()! That's because it's an accessor function for a property. We get and set the property in the normal way, but behind the scenes, the function is called.



                You can also create accessor functions with Object.defineProperty, Object.defineProperties, and the lesser-known second argument to Object.create.



                Arrow Function Expression (ES2015+)



                ES2015 brings us the arrow function. Here's one example:



                var a = [1, 2, 3];
                var b = a.map(n => n * 2);
                console.log(b.join(", ")); // 2, 4, 6


                See that n => n * 2 thing hiding in the map() call? That's a function.



                A couple of things about arrow functions:




                1. They don't have their own this. Instead, they close over the this of the context where they're defined. (They also close over arguments and, where relevant, super.) This means that the this within them is the same as the this where they're created, and cannot be changed.


                2. As you'll have noticed with the above, you don't use the keyword function; instead, you use =>.



                The n => n * 2 example above is one form of them. If you have multiple arguments to pass the function, you use parens:



                var a = [1, 2, 3];
                var b = a.map((n, i) => n * i);
                console.log(b.join(", ")); // 0, 2, 6


                (Remember that Array#map passes the entry as the first argument, and the index as the second.)



                In both cases, the body of the function is just an expression; the function's return value will automatically be the result of that expression (you don't use an explicit return).



                If you're doing more than just a single expression, use {} and an explicit return (if you need to return a value), as normal:



                var a = [
                {first: "Joe", last: "Bloggs"},
                {first: "Albert", last: "Bloggs"},
                {first: "Mary", last: "Albright"}
                ];
                a = a.sort((a, b) => {
                var rv = a.last.localeCompare(b.last);
                if (rv === 0) {
                rv = a.first.localeCompare(b.first);
                }
                return rv;
                });
                console.log(JSON.stringify(a));


                The version without { ... } is called an arrow function with an expression body or concise body. (Also: A concise arrow function.) The one with { ... } defining the body is an arrow function with a function body. (Also: A verbose arrow function.)



                Method Declaration in Object Initializer (ES2015+)



                ES2015 allows a shorter form of declaring a property that references a function; it looks like this:



                var o = {
                foo() {
                }
                };


                the equivalent in ES5 and earlier would be:



                var o = {
                foo: function foo() {
                }
                };


                Constructor and Method Declarations in class (ES2015+)



                ES2015 brings us class syntax, including declared constructors and methods:



                class Person {
                constructor(firstName, lastName) {
                this.firstName = firstName;
                this.lastName = lastName;
                }

                getFullName() {
                return this.firstName + " " + this.lastName;
                }
                }


                There are two function declarations above: One for the constructor, which gets the name Person, and one for getFullName, which is a function assigned to Person.prototype.







                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited Feb 7 at 15:10

























                answered Mar 4 '14 at 13:35









                T.J. Crowder

                676k12011961292




                676k12011961292








                • 3




                  then the name w is simply ignored ?
                  – BiAiB
                  Mar 4 '14 at 13:37






                • 8




                  @PellePenna: Function names are useful for lots of things. The two biggies in my view are recursion, and the name of the function being shown in call stacks, exception traces, and such.
                  – T.J. Crowder
                  Mar 4 '14 at 13:42






                • 10




                  This should now be the accepted answer. It's much more recent than the one above.
                  – Chaim Eliyah
                  Oct 2 '15 at 16:15






                • 4




                  @ChaimEliyah - "Accepting doesn't mean it's the best answer, it just means that it worked for the person who asked." source
                  – ScrapCode
                  Feb 10 '16 at 10:19






                • 6




                  @A.R.: Quite true. Amusingly, though, right above that it says "The best answers show up first so that they are always easy to find." Since the accepted answer shows up first even over higher-voted answers, the tour might be somewhat self-contradicting. ;-) Also a bit inaccurate, if we determine "best" by votes (which isn't reliable, it's just what we've got), "best" answers only show up first if you're using the "Votes" tab -- otherwise, the answers that are first are the active ones, or the oldest ones.
                  – T.J. Crowder
                  Feb 10 '16 at 10:32














                • 3




                  then the name w is simply ignored ?
                  – BiAiB
                  Mar 4 '14 at 13:37






                • 8




                  @PellePenna: Function names are useful for lots of things. The two biggies in my view are recursion, and the name of the function being shown in call stacks, exception traces, and such.
                  – T.J. Crowder
                  Mar 4 '14 at 13:42






                • 10




                  This should now be the accepted answer. It's much more recent than the one above.
                  – Chaim Eliyah
                  Oct 2 '15 at 16:15






                • 4




                  @ChaimEliyah - "Accepting doesn't mean it's the best answer, it just means that it worked for the person who asked." source
                  – ScrapCode
                  Feb 10 '16 at 10:19






                • 6




                  @A.R.: Quite true. Amusingly, though, right above that it says "The best answers show up first so that they are always easy to find." Since the accepted answer shows up first even over higher-voted answers, the tour might be somewhat self-contradicting. ;-) Also a bit inaccurate, if we determine "best" by votes (which isn't reliable, it's just what we've got), "best" answers only show up first if you're using the "Votes" tab -- otherwise, the answers that are first are the active ones, or the oldest ones.
                  – T.J. Crowder
                  Feb 10 '16 at 10:32








                3




                3




                then the name w is simply ignored ?
                – BiAiB
                Mar 4 '14 at 13:37




                then the name w is simply ignored ?
                – BiAiB
                Mar 4 '14 at 13:37




                8




                8




                @PellePenna: Function names are useful for lots of things. The two biggies in my view are recursion, and the name of the function being shown in call stacks, exception traces, and such.
                – T.J. Crowder
                Mar 4 '14 at 13:42




                @PellePenna: Function names are useful for lots of things. The two biggies in my view are recursion, and the name of the function being shown in call stacks, exception traces, and such.
                – T.J. Crowder
                Mar 4 '14 at 13:42




                10




                10




                This should now be the accepted answer. It's much more recent than the one above.
                – Chaim Eliyah
                Oct 2 '15 at 16:15




                This should now be the accepted answer. It's much more recent than the one above.
                – Chaim Eliyah
                Oct 2 '15 at 16:15




                4




                4




                @ChaimEliyah - "Accepting doesn't mean it's the best answer, it just means that it worked for the person who asked." source
                – ScrapCode
                Feb 10 '16 at 10:19




                @ChaimEliyah - "Accepting doesn't mean it's the best answer, it just means that it worked for the person who asked." source
                – ScrapCode
                Feb 10 '16 at 10:19




                6




                6




                @A.R.: Quite true. Amusingly, though, right above that it says "The best answers show up first so that they are always easy to find." Since the accepted answer shows up first even over higher-voted answers, the tour might be somewhat self-contradicting. ;-) Also a bit inaccurate, if we determine "best" by votes (which isn't reliable, it's just what we've got), "best" answers only show up first if you're using the "Votes" tab -- otherwise, the answers that are first are the active ones, or the oldest ones.
                – T.J. Crowder
                Feb 10 '16 at 10:32




                @A.R.: Quite true. Amusingly, though, right above that it says "The best answers show up first so that they are always easy to find." Since the accepted answer shows up first even over higher-voted answers, the tour might be somewhat self-contradicting. ;-) Also a bit inaccurate, if we determine "best" by votes (which isn't reliable, it's just what we've got), "best" answers only show up first if you're using the "Votes" tab -- otherwise, the answers that are first are the active ones, or the oldest ones.
                – T.J. Crowder
                Feb 10 '16 at 10:32











                137














                Speaking about the global context, both, the var statement and a FunctionDeclaration at the end will create a non-deleteable property on the global object, but the value of both can be overwritten.



                The subtle difference between the two ways is that when the Variable Instantiation process runs (before the actual code execution) all identifiers declared with var will be initialized with undefined, and the ones used by the FunctionDeclaration's will be available since that moment, for example:



                 alert(typeof foo); // 'function', it's already available
                alert(typeof bar); // 'undefined'
                function foo () {}
                var bar = function () {};
                alert(typeof bar); // 'function'


                The assignment of the bar FunctionExpression takes place until runtime.



                A global property created by a FunctionDeclaration can be overwritten without any problems just like a variable value, e.g.:



                 function test () {}
                test = null;


                Another obvious difference between your two examples is that the first function doesn't have a name, but the second has it, which can be really useful when debugging (i.e. inspecting a call stack).



                About your edited first example (foo = function() { alert('hello!'); };), it is an undeclared assignment, I would highly encourage you to always use the var keyword.



                With an assignment, without the var statement, if the referenced identifier is not found in the scope chain, it will become a deleteable property of the global object.



                Also, undeclared assignments throw a ReferenceError on ECMAScript 5 under Strict Mode.



                A must read:




                • Named function expressions demystified


                Note: This answer has been merged from another question, in which the major doubt and misconception from the OP was that identifiers declared with a FunctionDeclaration, couldn't be overwritten which is not the case.






                share|improve this answer























                • I did not know that functions could be overwritten in JavaScript! Also, that parse order is the big selling point for me. I guess I need to watch how I create functions.
                  – Xeoncross
                  Aug 8 '10 at 19:43






                • 2




                  +0 to the "Names function expressions demystified" article as it's 404ing. Possible mirror?: kangax.github.com/nfe
                  – Mr_Chimp
                  Nov 29 '11 at 15:10










                • @CMS Nice one. Bear in mind though I never saw the original so I don't know if that's a mirror or just another article with the same title!
                  – Mr_Chimp
                  Nov 29 '11 at 15:25










                • @Mr_Chimp I'm pretty sure it is, thewaybackmachine is saying that it got a 302 at crawl time and the redirection was to the link you provided.
                  – John
                  Jan 30 '12 at 15:18
















                137














                Speaking about the global context, both, the var statement and a FunctionDeclaration at the end will create a non-deleteable property on the global object, but the value of both can be overwritten.



                The subtle difference between the two ways is that when the Variable Instantiation process runs (before the actual code execution) all identifiers declared with var will be initialized with undefined, and the ones used by the FunctionDeclaration's will be available since that moment, for example:



                 alert(typeof foo); // 'function', it's already available
                alert(typeof bar); // 'undefined'
                function foo () {}
                var bar = function () {};
                alert(typeof bar); // 'function'


                The assignment of the bar FunctionExpression takes place until runtime.



                A global property created by a FunctionDeclaration can be overwritten without any problems just like a variable value, e.g.:



                 function test () {}
                test = null;


                Another obvious difference between your two examples is that the first function doesn't have a name, but the second has it, which can be really useful when debugging (i.e. inspecting a call stack).



                About your edited first example (foo = function() { alert('hello!'); };), it is an undeclared assignment, I would highly encourage you to always use the var keyword.



                With an assignment, without the var statement, if the referenced identifier is not found in the scope chain, it will become a deleteable property of the global object.



                Also, undeclared assignments throw a ReferenceError on ECMAScript 5 under Strict Mode.



                A must read:




                • Named function expressions demystified


                Note: This answer has been merged from another question, in which the major doubt and misconception from the OP was that identifiers declared with a FunctionDeclaration, couldn't be overwritten which is not the case.






                share|improve this answer























                • I did not know that functions could be overwritten in JavaScript! Also, that parse order is the big selling point for me. I guess I need to watch how I create functions.
                  – Xeoncross
                  Aug 8 '10 at 19:43






                • 2




                  +0 to the "Names function expressions demystified" article as it's 404ing. Possible mirror?: kangax.github.com/nfe
                  – Mr_Chimp
                  Nov 29 '11 at 15:10










                • @CMS Nice one. Bear in mind though I never saw the original so I don't know if that's a mirror or just another article with the same title!
                  – Mr_Chimp
                  Nov 29 '11 at 15:25










                • @Mr_Chimp I'm pretty sure it is, thewaybackmachine is saying that it got a 302 at crawl time and the redirection was to the link you provided.
                  – John
                  Jan 30 '12 at 15:18














                137












                137








                137






                Speaking about the global context, both, the var statement and a FunctionDeclaration at the end will create a non-deleteable property on the global object, but the value of both can be overwritten.



                The subtle difference between the two ways is that when the Variable Instantiation process runs (before the actual code execution) all identifiers declared with var will be initialized with undefined, and the ones used by the FunctionDeclaration's will be available since that moment, for example:



                 alert(typeof foo); // 'function', it's already available
                alert(typeof bar); // 'undefined'
                function foo () {}
                var bar = function () {};
                alert(typeof bar); // 'function'


                The assignment of the bar FunctionExpression takes place until runtime.



                A global property created by a FunctionDeclaration can be overwritten without any problems just like a variable value, e.g.:



                 function test () {}
                test = null;


                Another obvious difference between your two examples is that the first function doesn't have a name, but the second has it, which can be really useful when debugging (i.e. inspecting a call stack).



                About your edited first example (foo = function() { alert('hello!'); };), it is an undeclared assignment, I would highly encourage you to always use the var keyword.



                With an assignment, without the var statement, if the referenced identifier is not found in the scope chain, it will become a deleteable property of the global object.



                Also, undeclared assignments throw a ReferenceError on ECMAScript 5 under Strict Mode.



                A must read:




                • Named function expressions demystified


                Note: This answer has been merged from another question, in which the major doubt and misconception from the OP was that identifiers declared with a FunctionDeclaration, couldn't be overwritten which is not the case.






                share|improve this answer














                Speaking about the global context, both, the var statement and a FunctionDeclaration at the end will create a non-deleteable property on the global object, but the value of both can be overwritten.



                The subtle difference between the two ways is that when the Variable Instantiation process runs (before the actual code execution) all identifiers declared with var will be initialized with undefined, and the ones used by the FunctionDeclaration's will be available since that moment, for example:



                 alert(typeof foo); // 'function', it's already available
                alert(typeof bar); // 'undefined'
                function foo () {}
                var bar = function () {};
                alert(typeof bar); // 'function'


                The assignment of the bar FunctionExpression takes place until runtime.



                A global property created by a FunctionDeclaration can be overwritten without any problems just like a variable value, e.g.:



                 function test () {}
                test = null;


                Another obvious difference between your two examples is that the first function doesn't have a name, but the second has it, which can be really useful when debugging (i.e. inspecting a call stack).



                About your edited first example (foo = function() { alert('hello!'); };), it is an undeclared assignment, I would highly encourage you to always use the var keyword.



                With an assignment, without the var statement, if the referenced identifier is not found in the scope chain, it will become a deleteable property of the global object.



                Also, undeclared assignments throw a ReferenceError on ECMAScript 5 under Strict Mode.



                A must read:




                • Named function expressions demystified


                Note: This answer has been merged from another question, in which the major doubt and misconception from the OP was that identifiers declared with a FunctionDeclaration, couldn't be overwritten which is not the case.







                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited May 23 '17 at 12:10









                Community

                11




                11










                answered Aug 8 '10 at 19:32









                CMS

                586k162841809




                586k162841809












                • I did not know that functions could be overwritten in JavaScript! Also, that parse order is the big selling point for me. I guess I need to watch how I create functions.
                  – Xeoncross
                  Aug 8 '10 at 19:43






                • 2




                  +0 to the "Names function expressions demystified" article as it's 404ing. Possible mirror?: kangax.github.com/nfe
                  – Mr_Chimp
                  Nov 29 '11 at 15:10










                • @CMS Nice one. Bear in mind though I never saw the original so I don't know if that's a mirror or just another article with the same title!
                  – Mr_Chimp
                  Nov 29 '11 at 15:25










                • @Mr_Chimp I'm pretty sure it is, thewaybackmachine is saying that it got a 302 at crawl time and the redirection was to the link you provided.
                  – John
                  Jan 30 '12 at 15:18


















                • I did not know that functions could be overwritten in JavaScript! Also, that parse order is the big selling point for me. I guess I need to watch how I create functions.
                  – Xeoncross
                  Aug 8 '10 at 19:43






                • 2




                  +0 to the "Names function expressions demystified" article as it's 404ing. Possible mirror?: kangax.github.com/nfe
                  – Mr_Chimp
                  Nov 29 '11 at 15:10










                • @CMS Nice one. Bear in mind though I never saw the original so I don't know if that's a mirror or just another article with the same title!
                  – Mr_Chimp
                  Nov 29 '11 at 15:25










                • @Mr_Chimp I'm pretty sure it is, thewaybackmachine is saying that it got a 302 at crawl time and the redirection was to the link you provided.
                  – John
                  Jan 30 '12 at 15:18
















                I did not know that functions could be overwritten in JavaScript! Also, that parse order is the big selling point for me. I guess I need to watch how I create functions.
                – Xeoncross
                Aug 8 '10 at 19:43




                I did not know that functions could be overwritten in JavaScript! Also, that parse order is the big selling point for me. I guess I need to watch how I create functions.
                – Xeoncross
                Aug 8 '10 at 19:43




                2




                2




                +0 to the "Names function expressions demystified" article as it's 404ing. Possible mirror?: kangax.github.com/nfe
                – Mr_Chimp
                Nov 29 '11 at 15:10




                +0 to the "Names function expressions demystified" article as it's 404ing. Possible mirror?: kangax.github.com/nfe
                – Mr_Chimp
                Nov 29 '11 at 15:10












                @CMS Nice one. Bear in mind though I never saw the original so I don't know if that's a mirror or just another article with the same title!
                – Mr_Chimp
                Nov 29 '11 at 15:25




                @CMS Nice one. Bear in mind though I never saw the original so I don't know if that's a mirror or just another article with the same title!
                – Mr_Chimp
                Nov 29 '11 at 15:25












                @Mr_Chimp I'm pretty sure it is, thewaybackmachine is saying that it got a 302 at crawl time and the redirection was to the link you provided.
                – John
                Jan 30 '12 at 15:18




                @Mr_Chimp I'm pretty sure it is, thewaybackmachine is saying that it got a 302 at crawl time and the redirection was to the link you provided.
                – John
                Jan 30 '12 at 15:18











                115














                The two code snippets you've posted there will, for almost all purposes, behave the same way.



                However, the difference in behaviour is that with the first variant (var functionOne = function() {}), that function can only be called after that point in the code.



                With the second variant (function functionTwo()), the function is available to code that runs above where the function is declared.



                This is because with the first variant, the function is assigned to the variable foo at run time. In the second, the function is assigned to that identifier, foo, at parse time.



                More technical information



                JavaScript has three ways of defining functions.




                1. Your first snippet shows a function expression. This involves using the "function" operator to create a function - the result of that operator can be stored in any variable or object property. The function expression is powerful that way. The function expression is often called an "anonymous function", because it does not have to have a name,

                2. Your second example is a function declaration. This uses the "function" statement to create a function. The function is made available at parse time and can be called anywhere in that scope. You can still store it in a variable or object property later.

                3. The third way of defining a function is the "Function()" constructor, which is not shown in your original post. It's not recommended to use this as it works the same way as eval(), which has its problems.






                share|improve this answer




























                  115














                  The two code snippets you've posted there will, for almost all purposes, behave the same way.



                  However, the difference in behaviour is that with the first variant (var functionOne = function() {}), that function can only be called after that point in the code.



                  With the second variant (function functionTwo()), the function is available to code that runs above where the function is declared.



                  This is because with the first variant, the function is assigned to the variable foo at run time. In the second, the function is assigned to that identifier, foo, at parse time.



                  More technical information



                  JavaScript has three ways of defining functions.




                  1. Your first snippet shows a function expression. This involves using the "function" operator to create a function - the result of that operator can be stored in any variable or object property. The function expression is powerful that way. The function expression is often called an "anonymous function", because it does not have to have a name,

                  2. Your second example is a function declaration. This uses the "function" statement to create a function. The function is made available at parse time and can be called anywhere in that scope. You can still store it in a variable or object property later.

                  3. The third way of defining a function is the "Function()" constructor, which is not shown in your original post. It's not recommended to use this as it works the same way as eval(), which has its problems.






                  share|improve this answer


























                    115












                    115








                    115






                    The two code snippets you've posted there will, for almost all purposes, behave the same way.



                    However, the difference in behaviour is that with the first variant (var functionOne = function() {}), that function can only be called after that point in the code.



                    With the second variant (function functionTwo()), the function is available to code that runs above where the function is declared.



                    This is because with the first variant, the function is assigned to the variable foo at run time. In the second, the function is assigned to that identifier, foo, at parse time.



                    More technical information



                    JavaScript has three ways of defining functions.




                    1. Your first snippet shows a function expression. This involves using the "function" operator to create a function - the result of that operator can be stored in any variable or object property. The function expression is powerful that way. The function expression is often called an "anonymous function", because it does not have to have a name,

                    2. Your second example is a function declaration. This uses the "function" statement to create a function. The function is made available at parse time and can be called anywhere in that scope. You can still store it in a variable or object property later.

                    3. The third way of defining a function is the "Function()" constructor, which is not shown in your original post. It's not recommended to use this as it works the same way as eval(), which has its problems.






                    share|improve this answer














                    The two code snippets you've posted there will, for almost all purposes, behave the same way.



                    However, the difference in behaviour is that with the first variant (var functionOne = function() {}), that function can only be called after that point in the code.



                    With the second variant (function functionTwo()), the function is available to code that runs above where the function is declared.



                    This is because with the first variant, the function is assigned to the variable foo at run time. In the second, the function is assigned to that identifier, foo, at parse time.



                    More technical information



                    JavaScript has three ways of defining functions.




                    1. Your first snippet shows a function expression. This involves using the "function" operator to create a function - the result of that operator can be stored in any variable or object property. The function expression is powerful that way. The function expression is often called an "anonymous function", because it does not have to have a name,

                    2. Your second example is a function declaration. This uses the "function" statement to create a function. The function is made available at parse time and can be called anywhere in that scope. You can still store it in a variable or object property later.

                    3. The third way of defining a function is the "Function()" constructor, which is not shown in your original post. It's not recommended to use this as it works the same way as eval(), which has its problems.







                    share|improve this answer














                    share|improve this answer



                    share|improve this answer








                    edited Dec 28 '15 at 19:47









                    Peter Mortensen

                    13.5k1983111




                    13.5k1983111










                    answered Apr 20 '10 at 4:54









                    thomasrutter

                    88.3k20121147




                    88.3k20121147























                        96














                        A better explanation to Greg's answer



                        functionTwo();
                        function functionTwo() {
                        }


                        Why no error? We were always taught that expressions are executed from top to bottom(??)



                        Because:




                        Function declarations and variable declarations are always moved (hoisted) invisibly to the top of their containing scope by the JavaScript interpreter. Function parameters and language-defined names are, obviously, already there. ben cherry




                        This means that code like this:



                        functionOne();                  ---------------      var functionOne;
                        | is actually | functionOne();
                        var functionOne = function(){ | interpreted |-->
                        }; | like | functionOne = function(){
                        --------------- };


                        Notice that the assignment portion of the declarations were not hoisted. Only the name is hoisted.



                        But in the case with function declarations, the entire function body will be hoisted as well:



                        functionTwo();              ---------------      function functionTwo() {
                        | is actually | };
                        function functionTwo() { | interpreted |-->
                        } | like | functionTwo();
                        ---------------





                        share|improve this answer























                        • HI suhail thanks for clear info about function topic. Now my question is which one will be the first declaration in declaration hierarchy whether variable declaration (functionOne) or function declaration (functionTwo) ?
                          – Sharathi RB
                          Feb 2 '16 at 12:09
















                        96














                        A better explanation to Greg's answer



                        functionTwo();
                        function functionTwo() {
                        }


                        Why no error? We were always taught that expressions are executed from top to bottom(??)



                        Because:




                        Function declarations and variable declarations are always moved (hoisted) invisibly to the top of their containing scope by the JavaScript interpreter. Function parameters and language-defined names are, obviously, already there. ben cherry




                        This means that code like this:



                        functionOne();                  ---------------      var functionOne;
                        | is actually | functionOne();
                        var functionOne = function(){ | interpreted |-->
                        }; | like | functionOne = function(){
                        --------------- };


                        Notice that the assignment portion of the declarations were not hoisted. Only the name is hoisted.



                        But in the case with function declarations, the entire function body will be hoisted as well:



                        functionTwo();              ---------------      function functionTwo() {
                        | is actually | };
                        function functionTwo() { | interpreted |-->
                        } | like | functionTwo();
                        ---------------





                        share|improve this answer























                        • HI suhail thanks for clear info about function topic. Now my question is which one will be the first declaration in declaration hierarchy whether variable declaration (functionOne) or function declaration (functionTwo) ?
                          – Sharathi RB
                          Feb 2 '16 at 12:09














                        96












                        96








                        96






                        A better explanation to Greg's answer



                        functionTwo();
                        function functionTwo() {
                        }


                        Why no error? We were always taught that expressions are executed from top to bottom(??)



                        Because:




                        Function declarations and variable declarations are always moved (hoisted) invisibly to the top of their containing scope by the JavaScript interpreter. Function parameters and language-defined names are, obviously, already there. ben cherry




                        This means that code like this:



                        functionOne();                  ---------------      var functionOne;
                        | is actually | functionOne();
                        var functionOne = function(){ | interpreted |-->
                        }; | like | functionOne = function(){
                        --------------- };


                        Notice that the assignment portion of the declarations were not hoisted. Only the name is hoisted.



                        But in the case with function declarations, the entire function body will be hoisted as well:



                        functionTwo();              ---------------      function functionTwo() {
                        | is actually | };
                        function functionTwo() { | interpreted |-->
                        } | like | functionTwo();
                        ---------------





                        share|improve this answer














                        A better explanation to Greg's answer



                        functionTwo();
                        function functionTwo() {
                        }


                        Why no error? We were always taught that expressions are executed from top to bottom(??)



                        Because:




                        Function declarations and variable declarations are always moved (hoisted) invisibly to the top of their containing scope by the JavaScript interpreter. Function parameters and language-defined names are, obviously, already there. ben cherry




                        This means that code like this:



                        functionOne();                  ---------------      var functionOne;
                        | is actually | functionOne();
                        var functionOne = function(){ | interpreted |-->
                        }; | like | functionOne = function(){
                        --------------- };


                        Notice that the assignment portion of the declarations were not hoisted. Only the name is hoisted.



                        But in the case with function declarations, the entire function body will be hoisted as well:



                        functionTwo();              ---------------      function functionTwo() {
                        | is actually | };
                        function functionTwo() { | interpreted |-->
                        } | like | functionTwo();
                        ---------------






                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited May 23 '17 at 12:26









                        Community

                        11




                        11










                        answered Aug 9 '14 at 2:45









                        simple_human

                        8,70344563




                        8,70344563












                        • HI suhail thanks for clear info about function topic. Now my question is which one will be the first declaration in declaration hierarchy whether variable declaration (functionOne) or function declaration (functionTwo) ?
                          – Sharathi RB
                          Feb 2 '16 at 12:09


















                        • HI suhail thanks for clear info about function topic. Now my question is which one will be the first declaration in declaration hierarchy whether variable declaration (functionOne) or function declaration (functionTwo) ?
                          – Sharathi RB
                          Feb 2 '16 at 12:09
















                        HI suhail thanks for clear info about function topic. Now my question is which one will be the first declaration in declaration hierarchy whether variable declaration (functionOne) or function declaration (functionTwo) ?
                        – Sharathi RB
                        Feb 2 '16 at 12:09




                        HI suhail thanks for clear info about function topic. Now my question is which one will be the first declaration in declaration hierarchy whether variable declaration (functionOne) or function declaration (functionTwo) ?
                        – Sharathi RB
                        Feb 2 '16 at 12:09











                        87














                        Other commenters have already covered the semantic difference of the two variants above. I wanted to note a stylistic difference: Only the "assignment" variation can set a property of another object.



                        I often build JavaScript modules with a pattern like this:



                        (function(){
                        var exports = {};

                        function privateUtil() {
                        ...
                        }

                        exports.publicUtil = function() {
                        ...
                        };

                        return exports;
                        })();


                        With this pattern, your public functions will all use assignment, while your private functions use declaration.



                        (Note also that assignment should require a semicolon after the statement, while declaration prohibits it.)






                        share|improve this answer



















                        • 4




                          yuiblog.com/blog/2007/06/12/module-pattern is the primordial reference for the module pattern, as far as I can tell. (Though that article uses the var foo = function(){...} syntax even for private variables.
                          – Sean McMillan
                          Jun 3 '11 at 12:32










                        • This isn't entirely true in some older versions of IE, actually. (function window.onload() {} was a thing.)
                          – Ry-
                          Apr 21 '13 at 19:42
















                        87














                        Other commenters have already covered the semantic difference of the two variants above. I wanted to note a stylistic difference: Only the "assignment" variation can set a property of another object.



                        I often build JavaScript modules with a pattern like this:



                        (function(){
                        var exports = {};

                        function privateUtil() {
                        ...
                        }

                        exports.publicUtil = function() {
                        ...
                        };

                        return exports;
                        })();


                        With this pattern, your public functions will all use assignment, while your private functions use declaration.



                        (Note also that assignment should require a semicolon after the statement, while declaration prohibits it.)






                        share|improve this answer



















                        • 4




                          yuiblog.com/blog/2007/06/12/module-pattern is the primordial reference for the module pattern, as far as I can tell. (Though that article uses the var foo = function(){...} syntax even for private variables.
                          – Sean McMillan
                          Jun 3 '11 at 12:32










                        • This isn't entirely true in some older versions of IE, actually. (function window.onload() {} was a thing.)
                          – Ry-
                          Apr 21 '13 at 19:42














                        87












                        87








                        87






                        Other commenters have already covered the semantic difference of the two variants above. I wanted to note a stylistic difference: Only the "assignment" variation can set a property of another object.



                        I often build JavaScript modules with a pattern like this:



                        (function(){
                        var exports = {};

                        function privateUtil() {
                        ...
                        }

                        exports.publicUtil = function() {
                        ...
                        };

                        return exports;
                        })();


                        With this pattern, your public functions will all use assignment, while your private functions use declaration.



                        (Note also that assignment should require a semicolon after the statement, while declaration prohibits it.)






                        share|improve this answer














                        Other commenters have already covered the semantic difference of the two variants above. I wanted to note a stylistic difference: Only the "assignment" variation can set a property of another object.



                        I often build JavaScript modules with a pattern like this:



                        (function(){
                        var exports = {};

                        function privateUtil() {
                        ...
                        }

                        exports.publicUtil = function() {
                        ...
                        };

                        return exports;
                        })();


                        With this pattern, your public functions will all use assignment, while your private functions use declaration.



                        (Note also that assignment should require a semicolon after the statement, while declaration prohibits it.)







                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited Oct 19 '14 at 22:24









                        ROMANIA_engineer

                        32.8k19144141




                        32.8k19144141










                        answered Mar 3 '11 at 19:19









                        Sean McMillan

                        7,56544762




                        7,56544762








                        • 4




                          yuiblog.com/blog/2007/06/12/module-pattern is the primordial reference for the module pattern, as far as I can tell. (Though that article uses the var foo = function(){...} syntax even for private variables.
                          – Sean McMillan
                          Jun 3 '11 at 12:32










                        • This isn't entirely true in some older versions of IE, actually. (function window.onload() {} was a thing.)
                          – Ry-
                          Apr 21 '13 at 19:42














                        • 4




                          yuiblog.com/blog/2007/06/12/module-pattern is the primordial reference for the module pattern, as far as I can tell. (Though that article uses the var foo = function(){...} syntax even for private variables.
                          – Sean McMillan
                          Jun 3 '11 at 12:32










                        • This isn't entirely true in some older versions of IE, actually. (function window.onload() {} was a thing.)
                          – Ry-
                          Apr 21 '13 at 19:42








                        4




                        4




                        yuiblog.com/blog/2007/06/12/module-pattern is the primordial reference for the module pattern, as far as I can tell. (Though that article uses the var foo = function(){...} syntax even for private variables.
                        – Sean McMillan
                        Jun 3 '11 at 12:32




                        yuiblog.com/blog/2007/06/12/module-pattern is the primordial reference for the module pattern, as far as I can tell. (Though that article uses the var foo = function(){...} syntax even for private variables.
                        – Sean McMillan
                        Jun 3 '11 at 12:32












                        This isn't entirely true in some older versions of IE, actually. (function window.onload() {} was a thing.)
                        – Ry-
                        Apr 21 '13 at 19:42




                        This isn't entirely true in some older versions of IE, actually. (function window.onload() {} was a thing.)
                        – Ry-
                        Apr 21 '13 at 19:42











                        73














                        An illustration of when to prefer the first method to the second one is when you need to avoid overriding a function's previous definitions.



                        With



                        if (condition){
                        function myfunction(){
                        // Some code
                        }
                        }


                        , this definition of myfunction will override any previous definition, since it will be done at parse-time.



                        While



                        if (condition){
                        var myfunction = function (){
                        // Some code
                        }
                        }


                        does the correct job of defining myfunction only when condition is met.






                        share|improve this answer



















                        • 1




                          this example is good and is close to perfection, but could be improved. the better example would be to defined var myFunc = null; outside of a loop, or outside of an if/elseif/else block. Then you can conditionally assign different functions to the same variable. In JS, it is a better convention to assign a missing value to null, then to undefined. Therefore, you should declare myFunction as null first, then assign it later, conditionally.
                          – Alexander Mills
                          May 26 '15 at 20:31


















                        73














                        An illustration of when to prefer the first method to the second one is when you need to avoid overriding a function's previous definitions.



                        With



                        if (condition){
                        function myfunction(){
                        // Some code
                        }
                        }


                        , this definition of myfunction will override any previous definition, since it will be done at parse-time.



                        While



                        if (condition){
                        var myfunction = function (){
                        // Some code
                        }
                        }


                        does the correct job of defining myfunction only when condition is met.






                        share|improve this answer



















                        • 1




                          this example is good and is close to perfection, but could be improved. the better example would be to defined var myFunc = null; outside of a loop, or outside of an if/elseif/else block. Then you can conditionally assign different functions to the same variable. In JS, it is a better convention to assign a missing value to null, then to undefined. Therefore, you should declare myFunction as null first, then assign it later, conditionally.
                          – Alexander Mills
                          May 26 '15 at 20:31
















                        73












                        73








                        73






                        An illustration of when to prefer the first method to the second one is when you need to avoid overriding a function's previous definitions.



                        With



                        if (condition){
                        function myfunction(){
                        // Some code
                        }
                        }


                        , this definition of myfunction will override any previous definition, since it will be done at parse-time.



                        While



                        if (condition){
                        var myfunction = function (){
                        // Some code
                        }
                        }


                        does the correct job of defining myfunction only when condition is met.






                        share|improve this answer














                        An illustration of when to prefer the first method to the second one is when you need to avoid overriding a function's previous definitions.



                        With



                        if (condition){
                        function myfunction(){
                        // Some code
                        }
                        }


                        , this definition of myfunction will override any previous definition, since it will be done at parse-time.



                        While



                        if (condition){
                        var myfunction = function (){
                        // Some code
                        }
                        }


                        does the correct job of defining myfunction only when condition is met.







                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited Jun 29 '17 at 14:08









                        Alireza

                        45k12165119




                        45k12165119










                        answered Mar 29 '13 at 13:26









                        Mbengue Assane

                        2,24511213




                        2,24511213








                        • 1




                          this example is good and is close to perfection, but could be improved. the better example would be to defined var myFunc = null; outside of a loop, or outside of an if/elseif/else block. Then you can conditionally assign different functions to the same variable. In JS, it is a better convention to assign a missing value to null, then to undefined. Therefore, you should declare myFunction as null first, then assign it later, conditionally.
                          – Alexander Mills
                          May 26 '15 at 20:31
















                        • 1




                          this example is good and is close to perfection, but could be improved. the better example would be to defined var myFunc = null; outside of a loop, or outside of an if/elseif/else block. Then you can conditionally assign different functions to the same variable. In JS, it is a better convention to assign a missing value to null, then to undefined. Therefore, you should declare myFunction as null first, then assign it later, conditionally.
                          – Alexander Mills
                          May 26 '15 at 20:31










                        1




                        1




                        this example is good and is close to perfection, but could be improved. the better example would be to defined var myFunc = null; outside of a loop, or outside of an if/elseif/else block. Then you can conditionally assign different functions to the same variable. In JS, it is a better convention to assign a missing value to null, then to undefined. Therefore, you should declare myFunction as null first, then assign it later, conditionally.
                        – Alexander Mills
                        May 26 '15 at 20:31






                        this example is good and is close to perfection, but could be improved. the better example would be to defined var myFunc = null; outside of a loop, or outside of an if/elseif/else block. Then you can conditionally assign different functions to the same variable. In JS, it is a better convention to assign a missing value to null, then to undefined. Therefore, you should declare myFunction as null first, then assign it later, conditionally.
                        – Alexander Mills
                        May 26 '15 at 20:31













                        59














                        An important reason is to add one and only one variable as the "Root" of your namespace...



                        var MyNamespace = {}
                        MyNamespace.foo= function() {

                        }


                        or



                        var MyNamespace = {
                        foo: function() {
                        },
                        ...
                        }


                        There are many techniques for namespacing. It's become more important with the plethora of JavaScript modules available.



                        Also see How do I declare a namespace in JavaScript?






                        share|improve this answer



















                        • 3




                          It appears this answer was merged into this question from another question, and the wording might seem to be a tiny bit unrelated to this question. Would you consider editing the answer so it seems more directed specifically at this question? (to reiterate; this isn't your fault at all... just a side-effect of a merged question). You can also delete it, and I think you would keep your reputation. Or you can leave it; since it's old, it may not make a big difference.
                          – Andrew Barber
                          May 29 '13 at 21:13
















                        59














                        An important reason is to add one and only one variable as the "Root" of your namespace...



                        var MyNamespace = {}
                        MyNamespace.foo= function() {

                        }


                        or



                        var MyNamespace = {
                        foo: function() {
                        },
                        ...
                        }


                        There are many techniques for namespacing. It's become more important with the plethora of JavaScript modules available.



                        Also see How do I declare a namespace in JavaScript?






                        share|improve this answer



















                        • 3




                          It appears this answer was merged into this question from another question, and the wording might seem to be a tiny bit unrelated to this question. Would you consider editing the answer so it seems more directed specifically at this question? (to reiterate; this isn't your fault at all... just a side-effect of a merged question). You can also delete it, and I think you would keep your reputation. Or you can leave it; since it's old, it may not make a big difference.
                          – Andrew Barber
                          May 29 '13 at 21:13














                        59












                        59








                        59






                        An important reason is to add one and only one variable as the "Root" of your namespace...



                        var MyNamespace = {}
                        MyNamespace.foo= function() {

                        }


                        or



                        var MyNamespace = {
                        foo: function() {
                        },
                        ...
                        }


                        There are many techniques for namespacing. It's become more important with the plethora of JavaScript modules available.



                        Also see How do I declare a namespace in JavaScript?






                        share|improve this answer














                        An important reason is to add one and only one variable as the "Root" of your namespace...



                        var MyNamespace = {}
                        MyNamespace.foo= function() {

                        }


                        or



                        var MyNamespace = {
                        foo: function() {
                        },
                        ...
                        }


                        There are many techniques for namespacing. It's become more important with the plethora of JavaScript modules available.



                        Also see How do I declare a namespace in JavaScript?







                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited May 23 '17 at 11:55









                        Community

                        11




                        11










                        answered Aug 8 '10 at 19:44









                        Rob

                        4,79211726




                        4,79211726








                        • 3




                          It appears this answer was merged into this question from another question, and the wording might seem to be a tiny bit unrelated to this question. Would you consider editing the answer so it seems more directed specifically at this question? (to reiterate; this isn't your fault at all... just a side-effect of a merged question). You can also delete it, and I think you would keep your reputation. Or you can leave it; since it's old, it may not make a big difference.
                          – Andrew Barber
                          May 29 '13 at 21:13














                        • 3




                          It appears this answer was merged into this question from another question, and the wording might seem to be a tiny bit unrelated to this question. Would you consider editing the answer so it seems more directed specifically at this question? (to reiterate; this isn't your fault at all... just a side-effect of a merged question). You can also delete it, and I think you would keep your reputation. Or you can leave it; since it's old, it may not make a big difference.
                          – Andrew Barber
                          May 29 '13 at 21:13








                        3




                        3




                        It appears this answer was merged into this question from another question, and the wording might seem to be a tiny bit unrelated to this question. Would you consider editing the answer so it seems more directed specifically at this question? (to reiterate; this isn't your fault at all... just a side-effect of a merged question). You can also delete it, and I think you would keep your reputation. Or you can leave it; since it's old, it may not make a big difference.
                        – Andrew Barber
                        May 29 '13 at 21:13




                        It appears this answer was merged into this question from another question, and the wording might seem to be a tiny bit unrelated to this question. Would you consider editing the answer so it seems more directed specifically at this question? (to reiterate; this isn't your fault at all... just a side-effect of a merged question). You can also delete it, and I think you would keep your reputation. Or you can leave it; since it's old, it may not make a big difference.
                        – Andrew Barber
                        May 29 '13 at 21:13











                        52














                        Hoisting is the JavaScript interpreter’s action of moving all variable and function declarations to the top of the current scope.



                        However, only the actual declarations are hoisted. by leaving assignments where they are.




                        • variable's/Function's declared inside the page are global can access anywhere in that page.

                        • variable's/Functions declared inside the function are having local scope. means they are available/accessed inside the function body (scope), they are not available outside the function body.


                        Variable



                        Javascript is called loosely typed language. Which means Javascript variables can hold value of any Data-Type. Javascript automatically takes care of changing the variable-type based on the value/literal provided during runtime.



                        global_Page = 10;                                               var global_Page;      « undefined
                        « Integer literal, Number Type. ------------------- global_Page = 10; « Number
                        global_Page = 'Yash'; | Interpreted | global_Page = 'Yash'; « String
                        « String literal, String Type. « AS « global_Page = true; « Boolean
                        var global_Page = true; | | global_Page = function (){ « function
                        « Boolean Type ------------------- var local_functionblock; « undefined
                        global_Page = function (){ local_functionblock = 777;« Number
                        var local_functionblock = 777; };
                        // Assigning function as a data.
                        };




                        Function



                        function Identifier_opt ( FormalParameterList_opt ) { 
                        FunctionBody | sequence of statements

                        « return; Default undefined
                        « return 'some data';
                        }



                        • functions declared inside the page are hoisted to top of the page having global access.

                        • functions declared inside the function-block are hoisted to top of the block.


                        • Default return value of function is 'undefined', Variable declaration default value also 'undefined'



                          Scope with respect to function-block global. 
                          Scope with respect to page undefined | not available.



                        Function Declaration



                        function globalAccess() {                                  function globalAccess() {      
                        } ------------------- }
                        globalAccess(); | | function globalAccess() { « Re-Defined / overridden.
                        localAccess(); « Hoisted As « function localAccess() {
                        function globalAccess() { | | }
                        localAccess(); ------------------- localAccess(); « function accessed with in globalAccess() only.
                        function localAccess() { }
                        } globalAccess();
                        } localAccess(); « ReferenceError as the function is not defined


                        Function Expression



                                10;                 « literal
                        (10); « Expression (10).toString() -> '10'
                        var a;
                        a = 10; « Expression var a.toString() -> '10'
                        (function invoke() { « Expression Function
                        console.log('Self Invoking'); (function () {
                        }); }) () -> 'Self Invoking'

                        var f;
                        f = function (){ « Expression var Function
                        console.log('var Function'); f () -> 'var Function'
                        };


                        Function assigned to variable Example:



                        (function selfExecuting(){
                        console.log('IIFE - Immediately-Invoked Function Expression');
                        }());

                        var anonymous = function (){
                        console.log('anonymous function Expression');
                        };

                        var namedExpression = function for_InternalUSE(fact){
                        if(fact === 1){
                        return 1;
                        }

                        var localExpression = function(){
                        console.log('Local to the parent Function Scope');
                        };
                        globalExpression = function(){
                        console.log('creates a new global variable, then assigned this function.');
                        };

                        //return; //undefined.
                        return fact * for_InternalUSE( fact - 1);
                        };

                        namedExpression();
                        globalExpression();


                        javascript interpreted as



                        var anonymous;
                        var namedExpression;
                        var globalExpression;

                        anonymous = function (){
                        console.log('anonymous function Expression');
                        };

                        namedExpression = function for_InternalUSE(fact){
                        var localExpression;

                        if(fact === 1){
                        return 1;
                        }
                        localExpression = function(){
                        console.log('Local to the parent Function Scope');
                        };
                        globalExpression = function(){
                        console.log('creates a new global variable, then assigned this function.');
                        };

                        return fact * for_InternalUSE( fact - 1); // DEFAULT UNDEFINED.
                        };

                        namedExpression(10);
                        globalExpression();


                        You can check function declaration, expression test over different browser's using jsperf Test Runner





                        ES5 Constructor Function Classes: Function objects created using Function.prototype.bind



                        JavaScript treats functions as first-class objects, so being an object, you can assign properties to a function.



                        function Shape(id) { // Function Declaration
                        this.id = id;
                        };
                        // Adding a prototyped method to a function.
                        Shape.prototype.getID = function () {
                        return this.id;
                        };
                        Shape.prototype.setID = function ( id ) {
                        this.id = id;
                        };

                        var expFn = Shape; // Function Expression

                        var funObj = new Shape( ); // Function Object
                        funObj.hasOwnProperty('prototype'); // false
                        funObj.setID( 10 );
                        console.log( funObj.getID() ); // 10




                        ES6 introduced Arrow function: An arrow function expression has a shorter syntax, they are best suited for non-method functions, and they cannot be used as constructors.




                        ArrowFunction : ArrowParameters => ConciseBody.



                        const fn = (item) => { return item & 1 ? 'Odd' : 'Even'; };
                        console.log( fn(2) ); // Even
                        console.log( fn(3) ); // Odd






                        share|improve this answer



















                        • 3




                          ahm, your answer... isn't it ambiguous? well written though so +1 for spending and writing too much info.
                          – Danish
                          Jan 31 '16 at 17:56
















                        52














                        Hoisting is the JavaScript interpreter’s action of moving all variable and function declarations to the top of the current scope.



                        However, only the actual declarations are hoisted. by leaving assignments where they are.




                        • variable's/Function's declared inside the page are global can access anywhere in that page.

                        • variable's/Functions declared inside the function are having local scope. means they are available/accessed inside the function body (scope), they are not available outside the function body.


                        Variable



                        Javascript is called loosely typed language. Which means Javascript variables can hold value of any Data-Type. Javascript automatically takes care of changing the variable-type based on the value/literal provided during runtime.



                        global_Page = 10;                                               var global_Page;      « undefined
                        « Integer literal, Number Type. ------------------- global_Page = 10; « Number
                        global_Page = 'Yash'; | Interpreted | global_Page = 'Yash'; « String
                        « String literal, String Type. « AS « global_Page = true; « Boolean
                        var global_Page = true; | | global_Page = function (){ « function
                        « Boolean Type ------------------- var local_functionblock; « undefined
                        global_Page = function (){ local_functionblock = 777;« Number
                        var local_functionblock = 777; };
                        // Assigning function as a data.
                        };




                        Function



                        function Identifier_opt ( FormalParameterList_opt ) { 
                        FunctionBody | sequence of statements

                        « return; Default undefined
                        « return 'some data';
                        }



                        • functions declared inside the page are hoisted to top of the page having global access.

                        • functions declared inside the function-block are hoisted to top of the block.


                        • Default return value of function is 'undefined', Variable declaration default value also 'undefined'



                          Scope with respect to function-block global. 
                          Scope with respect to page undefined | not available.



                        Function Declaration



                        function globalAccess() {                                  function globalAccess() {      
                        } ------------------- }
                        globalAccess(); | | function globalAccess() { « Re-Defined / overridden.
                        localAccess(); « Hoisted As « function localAccess() {
                        function globalAccess() { | | }
                        localAccess(); ------------------- localAccess(); « function accessed with in globalAccess() only.
                        function localAccess() { }
                        } globalAccess();
                        } localAccess(); « ReferenceError as the function is not defined


                        Function Expression



                                10;                 « literal
                        (10); « Expression (10).toString() -> '10'
                        var a;
                        a = 10; « Expression var a.toString() -> '10'
                        (function invoke() { « Expression Function
                        console.log('Self Invoking'); (function () {
                        }); }) () -> 'Self Invoking'

                        var f;
                        f = function (){ « Expression var Function
                        console.log('var Function'); f () -> 'var Function'
                        };


                        Function assigned to variable Example:



                        (function selfExecuting(){
                        console.log('IIFE - Immediately-Invoked Function Expression');
                        }());

                        var anonymous = function (){
                        console.log('anonymous function Expression');
                        };

                        var namedExpression = function for_InternalUSE(fact){
                        if(fact === 1){
                        return 1;
                        }

                        var localExpression = function(){
                        console.log('Local to the parent Function Scope');
                        };
                        globalExpression = function(){
                        console.log('creates a new global variable, then assigned this function.');
                        };

                        //return; //undefined.
                        return fact * for_InternalUSE( fact - 1);
                        };

                        namedExpression();
                        globalExpression();


                        javascript interpreted as



                        var anonymous;
                        var namedExpression;
                        var globalExpression;

                        anonymous = function (){
                        console.log('anonymous function Expression');
                        };

                        namedExpression = function for_InternalUSE(fact){
                        var localExpression;

                        if(fact === 1){
                        return 1;
                        }
                        localExpression = function(){
                        console.log('Local to the parent Function Scope');
                        };
                        globalExpression = function(){
                        console.log('creates a new global variable, then assigned this function.');
                        };

                        return fact * for_InternalUSE( fact - 1); // DEFAULT UNDEFINED.
                        };

                        namedExpression(10);
                        globalExpression();


                        You can check function declaration, expression test over different browser's using jsperf Test Runner





                        ES5 Constructor Function Classes: Function objects created using Function.prototype.bind



                        JavaScript treats functions as first-class objects, so being an object, you can assign properties to a function.



                        function Shape(id) { // Function Declaration
                        this.id = id;
                        };
                        // Adding a prototyped method to a function.
                        Shape.prototype.getID = function () {
                        return this.id;
                        };
                        Shape.prototype.setID = function ( id ) {
                        this.id = id;
                        };

                        var expFn = Shape; // Function Expression

                        var funObj = new Shape( ); // Function Object
                        funObj.hasOwnProperty('prototype'); // false
                        funObj.setID( 10 );
                        console.log( funObj.getID() ); // 10




                        ES6 introduced Arrow function: An arrow function expression has a shorter syntax, they are best suited for non-method functions, and they cannot be used as constructors.




                        ArrowFunction : ArrowParameters => ConciseBody.



                        const fn = (item) => { return item & 1 ? 'Odd' : 'Even'; };
                        console.log( fn(2) ); // Even
                        console.log( fn(3) ); // Odd






                        share|improve this answer



















                        • 3




                          ahm, your answer... isn't it ambiguous? well written though so +1 for spending and writing too much info.
                          – Danish
                          Jan 31 '16 at 17:56














                        52












                        52








                        52






                        Hoisting is the JavaScript interpreter’s action of moving all variable and function declarations to the top of the current scope.



                        However, only the actual declarations are hoisted. by leaving assignments where they are.




                        • variable's/Function's declared inside the page are global can access anywhere in that page.

                        • variable's/Functions declared inside the function are having local scope. means they are available/accessed inside the function body (scope), they are not available outside the function body.


                        Variable



                        Javascript is called loosely typed language. Which means Javascript variables can hold value of any Data-Type. Javascript automatically takes care of changing the variable-type based on the value/literal provided during runtime.



                        global_Page = 10;                                               var global_Page;      « undefined
                        « Integer literal, Number Type. ------------------- global_Page = 10; « Number
                        global_Page = 'Yash'; | Interpreted | global_Page = 'Yash'; « String
                        « String literal, String Type. « AS « global_Page = true; « Boolean
                        var global_Page = true; | | global_Page = function (){ « function
                        « Boolean Type ------------------- var local_functionblock; « undefined
                        global_Page = function (){ local_functionblock = 777;« Number
                        var local_functionblock = 777; };
                        // Assigning function as a data.
                        };




                        Function



                        function Identifier_opt ( FormalParameterList_opt ) { 
                        FunctionBody | sequence of statements

                        « return; Default undefined
                        « return 'some data';
                        }



                        • functions declared inside the page are hoisted to top of the page having global access.

                        • functions declared inside the function-block are hoisted to top of the block.


                        • Default return value of function is 'undefined', Variable declaration default value also 'undefined'



                          Scope with respect to function-block global. 
                          Scope with respect to page undefined | not available.



                        Function Declaration



                        function globalAccess() {                                  function globalAccess() {      
                        } ------------------- }
                        globalAccess(); | | function globalAccess() { « Re-Defined / overridden.
                        localAccess(); « Hoisted As « function localAccess() {
                        function globalAccess() { | | }
                        localAccess(); ------------------- localAccess(); « function accessed with in globalAccess() only.
                        function localAccess() { }
                        } globalAccess();
                        } localAccess(); « ReferenceError as the function is not defined


                        Function Expression



                                10;                 « literal
                        (10); « Expression (10).toString() -> '10'
                        var a;
                        a = 10; « Expression var a.toString() -> '10'
                        (function invoke() { « Expression Function
                        console.log('Self Invoking'); (function () {
                        }); }) () -> 'Self Invoking'

                        var f;
                        f = function (){ « Expression var Function
                        console.log('var Function'); f () -> 'var Function'
                        };


                        Function assigned to variable Example:



                        (function selfExecuting(){
                        console.log('IIFE - Immediately-Invoked Function Expression');
                        }());

                        var anonymous = function (){
                        console.log('anonymous function Expression');
                        };

                        var namedExpression = function for_InternalUSE(fact){
                        if(fact === 1){
                        return 1;
                        }

                        var localExpression = function(){
                        console.log('Local to the parent Function Scope');
                        };
                        globalExpression = function(){
                        console.log('creates a new global variable, then assigned this function.');
                        };

                        //return; //undefined.
                        return fact * for_InternalUSE( fact - 1);
                        };

                        namedExpression();
                        globalExpression();


                        javascript interpreted as



                        var anonymous;
                        var namedExpression;
                        var globalExpression;

                        anonymous = function (){
                        console.log('anonymous function Expression');
                        };

                        namedExpression = function for_InternalUSE(fact){
                        var localExpression;

                        if(fact === 1){
                        return 1;
                        }
                        localExpression = function(){
                        console.log('Local to the parent Function Scope');
                        };
                        globalExpression = function(){
                        console.log('creates a new global variable, then assigned this function.');
                        };

                        return fact * for_InternalUSE( fact - 1); // DEFAULT UNDEFINED.
                        };

                        namedExpression(10);
                        globalExpression();


                        You can check function declaration, expression test over different browser's using jsperf Test Runner





                        ES5 Constructor Function Classes: Function objects created using Function.prototype.bind



                        JavaScript treats functions as first-class objects, so being an object, you can assign properties to a function.



                        function Shape(id) { // Function Declaration
                        this.id = id;
                        };
                        // Adding a prototyped method to a function.
                        Shape.prototype.getID = function () {
                        return this.id;
                        };
                        Shape.prototype.setID = function ( id ) {
                        this.id = id;
                        };

                        var expFn = Shape; // Function Expression

                        var funObj = new Shape( ); // Function Object
                        funObj.hasOwnProperty('prototype'); // false
                        funObj.setID( 10 );
                        console.log( funObj.getID() ); // 10




                        ES6 introduced Arrow function: An arrow function expression has a shorter syntax, they are best suited for non-method functions, and they cannot be used as constructors.




                        ArrowFunction : ArrowParameters => ConciseBody.



                        const fn = (item) => { return item & 1 ? 'Odd' : 'Even'; };
                        console.log( fn(2) ); // Even
                        console.log( fn(3) ); // Odd






                        share|improve this answer














                        Hoisting is the JavaScript interpreter’s action of moving all variable and function declarations to the top of the current scope.



                        However, only the actual declarations are hoisted. by leaving assignments where they are.




                        • variable's/Function's declared inside the page are global can access anywhere in that page.

                        • variable's/Functions declared inside the function are having local scope. means they are available/accessed inside the function body (scope), they are not available outside the function body.


                        Variable



                        Javascript is called loosely typed language. Which means Javascript variables can hold value of any Data-Type. Javascript automatically takes care of changing the variable-type based on the value/literal provided during runtime.



                        global_Page = 10;                                               var global_Page;      « undefined
                        « Integer literal, Number Type. ------------------- global_Page = 10; « Number
                        global_Page = 'Yash'; | Interpreted | global_Page = 'Yash'; « String
                        « String literal, String Type. « AS « global_Page = true; « Boolean
                        var global_Page = true; | | global_Page = function (){ « function
                        « Boolean Type ------------------- var local_functionblock; « undefined
                        global_Page = function (){ local_functionblock = 777;« Number
                        var local_functionblock = 777; };
                        // Assigning function as a data.
                        };




                        Function



                        function Identifier_opt ( FormalParameterList_opt ) { 
                        FunctionBody | sequence of statements

                        « return; Default undefined
                        « return 'some data';
                        }



                        • functions declared inside the page are hoisted to top of the page having global access.

                        • functions declared inside the function-block are hoisted to top of the block.


                        • Default return value of function is 'undefined', Variable declaration default value also 'undefined'



                          Scope with respect to function-block global. 
                          Scope with respect to page undefined | not available.



                        Function Declaration



                        function globalAccess() {                                  function globalAccess() {      
                        } ------------------- }
                        globalAccess(); | | function globalAccess() { « Re-Defined / overridden.
                        localAccess(); « Hoisted As « function localAccess() {
                        function globalAccess() { | | }
                        localAccess(); ------------------- localAccess(); « function accessed with in globalAccess() only.
                        function localAccess() { }
                        } globalAccess();
                        } localAccess(); « ReferenceError as the function is not defined


                        Function Expression



                                10;                 « literal
                        (10); « Expression (10).toString() -> '10'
                        var a;
                        a = 10; « Expression var a.toString() -> '10'
                        (function invoke() { « Expression Function
                        console.log('Self Invoking'); (function () {
                        }); }) () -> 'Self Invoking'

                        var f;
                        f = function (){ « Expression var Function
                        console.log('var Function'); f () -> 'var Function'
                        };


                        Function assigned to variable Example:



                        (function selfExecuting(){
                        console.log('IIFE - Immediately-Invoked Function Expression');
                        }());

                        var anonymous = function (){
                        console.log('anonymous function Expression');
                        };

                        var namedExpression = function for_InternalUSE(fact){
                        if(fact === 1){
                        return 1;
                        }

                        var localExpression = function(){
                        console.log('Local to the parent Function Scope');
                        };
                        globalExpression = function(){
                        console.log('creates a new global variable, then assigned this function.');
                        };

                        //return; //undefined.
                        return fact * for_InternalUSE( fact - 1);
                        };

                        namedExpression();
                        globalExpression();


                        javascript interpreted as



                        var anonymous;
                        var namedExpression;
                        var globalExpression;

                        anonymous = function (){
                        console.log('anonymous function Expression');
                        };

                        namedExpression = function for_InternalUSE(fact){
                        var localExpression;

                        if(fact === 1){
                        return 1;
                        }
                        localExpression = function(){
                        console.log('Local to the parent Function Scope');
                        };
                        globalExpression = function(){
                        console.log('creates a new global variable, then assigned this function.');
                        };

                        return fact * for_InternalUSE( fact - 1); // DEFAULT UNDEFINED.
                        };

                        namedExpression(10);
                        globalExpression();


                        You can check function declaration, expression test over different browser's using jsperf Test Runner





                        ES5 Constructor Function Classes: Function objects created using Function.prototype.bind



                        JavaScript treats functions as first-class objects, so being an object, you can assign properties to a function.



                        function Shape(id) { // Function Declaration
                        this.id = id;
                        };
                        // Adding a prototyped method to a function.
                        Shape.prototype.getID = function () {
                        return this.id;
                        };
                        Shape.prototype.setID = function ( id ) {
                        this.id = id;
                        };

                        var expFn = Shape; // Function Expression

                        var funObj = new Shape( ); // Function Object
                        funObj.hasOwnProperty('prototype'); // false
                        funObj.setID( 10 );
                        console.log( funObj.getID() ); // 10




                        ES6 introduced Arrow function: An arrow function expression has a shorter syntax, they are best suited for non-method functions, and they cannot be used as constructors.




                        ArrowFunction : ArrowParameters => ConciseBody.



                        const fn = (item) => { return item & 1 ? 'Odd' : 'Even'; };
                        console.log( fn(2) ); // Even
                        console.log( fn(3) ); // Odd







                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited Sep 28 '17 at 6:35

























                        answered Jan 25 '16 at 14:46









                        Yash

                        4,27712640




                        4,27712640








                        • 3




                          ahm, your answer... isn't it ambiguous? well written though so +1 for spending and writing too much info.
                          – Danish
                          Jan 31 '16 at 17:56














                        • 3




                          ahm, your answer... isn't it ambiguous? well written though so +1 for spending and writing too much info.
                          – Danish
                          Jan 31 '16 at 17:56








                        3




                        3




                        ahm, your answer... isn't it ambiguous? well written though so +1 for spending and writing too much info.
                        – Danish
                        Jan 31 '16 at 17:56




                        ahm, your answer... isn't it ambiguous? well written though so +1 for spending and writing too much info.
                        – Danish
                        Jan 31 '16 at 17:56











                        36














                        I'm adding my own answer just because everyone else has covered the hoisting part thoroughly.



                        I've wondered about which way is better for a long while now, and thanks to http://jsperf.com now I know :)



                        enter image description here



                        Function declarations are faster, and that's what really matters in web dev right? ;)






                        share|improve this answer

















                        • 7




                          I'd say that maintainability is the most important aspect of most code. Performance is important, but in most cases IO is likely to be a bigger bottleneck that the way you define your functions. However there are some problems where you need every bit of performance you can get and this is useful in those cases. Also good to have an answer here that answers clearly a well defined part of the question.
                          – Richard Garside
                          May 2 '15 at 15:22






                        • 3




                          Well, I found it to be other way around with Firefox. jsperf.com/sandytest
                          – Sandeep Nayak
                          Nov 17 '15 at 14:15






                        • 2




                          Microbenchmarks always fail. Looking to jsperf.com is waster of time. What you really need is to look to JS engine source code, official documentation, or at least sniff dev blogs or mail lists.
                          – gavenkoa
                          Jan 10 '16 at 15:13












                        • Just an update, since I've gone full functional programming style in JavaScript now, I never use declarations, only function expressions so I can chain and call my functions by their variable names. Check out RamdaJS...
                          – Leon Gaban
                          Dec 28 '16 at 16:56










                        • @SandeepNayak I just run your own test in Firefox 50.0.0 / Windows 7 0.0.0, and it actually is the same way as Leon's. So if your test is correct, I would conclude that jsperf's tests are not indicatives, and it all depend on your browser and / or OS version, or in the particular state of the current machine in that particular moment.
                          – ocramot
                          Jan 10 '17 at 13:40


















                        36














                        I'm adding my own answer just because everyone else has covered the hoisting part thoroughly.



                        I've wondered about which way is better for a long while now, and thanks to http://jsperf.com now I know :)



                        enter image description here



                        Function declarations are faster, and that's what really matters in web dev right? ;)






                        share|improve this answer

















                        • 7




                          I'd say that maintainability is the most important aspect of most code. Performance is important, but in most cases IO is likely to be a bigger bottleneck that the way you define your functions. However there are some problems where you need every bit of performance you can get and this is useful in those cases. Also good to have an answer here that answers clearly a well defined part of the question.
                          – Richard Garside
                          May 2 '15 at 15:22






                        • 3




                          Well, I found it to be other way around with Firefox. jsperf.com/sandytest
                          – Sandeep Nayak
                          Nov 17 '15 at 14:15






                        • 2




                          Microbenchmarks always fail. Looking to jsperf.com is waster of time. What you really need is to look to JS engine source code, official documentation, or at least sniff dev blogs or mail lists.
                          – gavenkoa
                          Jan 10 '16 at 15:13












                        • Just an update, since I've gone full functional programming style in JavaScript now, I never use declarations, only function expressions so I can chain and call my functions by their variable names. Check out RamdaJS...
                          – Leon Gaban
                          Dec 28 '16 at 16:56










                        • @SandeepNayak I just run your own test in Firefox 50.0.0 / Windows 7 0.0.0, and it actually is the same way as Leon's. So if your test is correct, I would conclude that jsperf's tests are not indicatives, and it all depend on your browser and / or OS version, or in the particular state of the current machine in that particular moment.
                          – ocramot
                          Jan 10 '17 at 13:40
















                        36












                        36








                        36






                        I'm adding my own answer just because everyone else has covered the hoisting part thoroughly.



                        I've wondered about which way is better for a long while now, and thanks to http://jsperf.com now I know :)



                        enter image description here



                        Function declarations are faster, and that's what really matters in web dev right? ;)






                        share|improve this answer












                        I'm adding my own answer just because everyone else has covered the hoisting part thoroughly.



                        I've wondered about which way is better for a long while now, and thanks to http://jsperf.com now I know :)



                        enter image description here



                        Function declarations are faster, and that's what really matters in web dev right? ;)







                        share|improve this answer












                        share|improve this answer



                        share|improve this answer










                        answered May 1 '15 at 15:06









                        Leon Gaban

                        9,42139173326




                        9,42139173326








                        • 7




                          I'd say that maintainability is the most important aspect of most code. Performance is important, but in most cases IO is likely to be a bigger bottleneck that the way you define your functions. However there are some problems where you need every bit of performance you can get and this is useful in those cases. Also good to have an answer here that answers clearly a well defined part of the question.
                          – Richard Garside
                          May 2 '15 at 15:22






                        • 3




                          Well, I found it to be other way around with Firefox. jsperf.com/sandytest
                          – Sandeep Nayak
                          Nov 17 '15 at 14:15






                        • 2




                          Microbenchmarks always fail. Looking to jsperf.com is waster of time. What you really need is to look to JS engine source code, official documentation, or at least sniff dev blogs or mail lists.
                          – gavenkoa
                          Jan 10 '16 at 15:13












                        • Just an update, since I've gone full functional programming style in JavaScript now, I never use declarations, only function expressions so I can chain and call my functions by their variable names. Check out RamdaJS...
                          – Leon Gaban
                          Dec 28 '16 at 16:56










                        • @SandeepNayak I just run your own test in Firefox 50.0.0 / Windows 7 0.0.0, and it actually is the same way as Leon's. So if your test is correct, I would conclude that jsperf's tests are not indicatives, and it all depend on your browser and / or OS version, or in the particular state of the current machine in that particular moment.
                          – ocramot
                          Jan 10 '17 at 13:40
















                        • 7




                          I'd say that maintainability is the most important aspect of most code. Performance is important, but in most cases IO is likely to be a bigger bottleneck that the way you define your functions. However there are some problems where you need every bit of performance you can get and this is useful in those cases. Also good to have an answer here that answers clearly a well defined part of the question.
                          – Richard Garside
                          May 2 '15 at 15:22






                        • 3




                          Well, I found it to be other way around with Firefox. jsperf.com/sandytest
                          – Sandeep Nayak
                          Nov 17 '15 at 14:15






                        • 2




                          Microbenchmarks always fail. Looking to jsperf.com is waster of time. What you really need is to look to JS engine source code, official documentation, or at least sniff dev blogs or mail lists.
                          – gavenkoa
                          Jan 10 '16 at 15:13












                        • Just an update, since I've gone full functional programming style in JavaScript now, I never use declarations, only function expressions so I can chain and call my functions by their variable names. Check out RamdaJS...
                          – Leon Gaban
                          Dec 28 '16 at 16:56










                        • @SandeepNayak I just run your own test in Firefox 50.0.0 / Windows 7 0.0.0, and it actually is the same way as Leon's. So if your test is correct, I would conclude that jsperf's tests are not indicatives, and it all depend on your browser and / or OS version, or in the particular state of the current machine in that particular moment.
                          – ocramot
                          Jan 10 '17 at 13:40










                        7




                        7




                        I'd say that maintainability is the most important aspect of most code. Performance is important, but in most cases IO is likely to be a bigger bottleneck that the way you define your functions. However there are some problems where you need every bit of performance you can get and this is useful in those cases. Also good to have an answer here that answers clearly a well defined part of the question.
                        – Richard Garside
                        May 2 '15 at 15:22




                        I'd say that maintainability is the most important aspect of most code. Performance is important, but in most cases IO is likely to be a bigger bottleneck that the way you define your functions. However there are some problems where you need every bit of performance you can get and this is useful in those cases. Also good to have an answer here that answers clearly a well defined part of the question.
                        – Richard Garside
                        May 2 '15 at 15:22




                        3




                        3




                        Well, I found it to be other way around with Firefox. jsperf.com/sandytest
                        – Sandeep Nayak
                        Nov 17 '15 at 14:15




                        Well, I found it to be other way around with Firefox. jsperf.com/sandytest
                        – Sandeep Nayak
                        Nov 17 '15 at 14:15




                        2




                        2




                        Microbenchmarks always fail. Looking to jsperf.com is waster of time. What you really need is to look to JS engine source code, official documentation, or at least sniff dev blogs or mail lists.
                        – gavenkoa
                        Jan 10 '16 at 15:13






                        Microbenchmarks always fail. Looking to jsperf.com is waster of time. What you really need is to look to JS engine source code, official documentation, or at least sniff dev blogs or mail lists.
                        – gavenkoa
                        Jan 10 '16 at 15:13














                        Just an update, since I've gone full functional programming style in JavaScript now, I never use declarations, only function expressions so I can chain and call my functions by their variable names. Check out RamdaJS...
                        – Leon Gaban
                        Dec 28 '16 at 16:56




                        Just an update, since I've gone full functional programming style in JavaScript now, I never use declarations, only function expressions so I can chain and call my functions by their variable names. Check out RamdaJS...
                        – Leon Gaban
                        Dec 28 '16 at 16:56












                        @SandeepNayak I just run your own test in Firefox 50.0.0 / Windows 7 0.0.0, and it actually is the same way as Leon's. So if your test is correct, I would conclude that jsperf's tests are not indicatives, and it all depend on your browser and / or OS version, or in the particular state of the current machine in that particular moment.
                        – ocramot
                        Jan 10 '17 at 13:40






                        @SandeepNayak I just run your own test in Firefox 50.0.0 / Windows 7 0.0.0, and it actually is the same way as Leon's. So if your test is correct, I would conclude that jsperf's tests are not indicatives, and it all depend on your browser and / or OS version, or in the particular state of the current machine in that particular moment.
                        – ocramot
                        Jan 10 '17 at 13:40













                        32














                        A function declaration and a function expression assigned to a variable behave the same once the binding is established.



                        There is a difference however at how and when the function object is actually associated with its variable. This difference is due to the mechanism called variable hoisting in JavaScript.



                        Basically, all function declarations and variable declarations are hoisted to the top of the function in which the declaration occurs (this is why we say that JavaScript has function scope).




                        • When a function declaration is hoisted, the function body "follows"
                          so when the function body is evaluated, the variable will immediately
                          be bound to a function object.


                        • When a variable declaration is hoisted, the initialization does not
                          follow, but is "left behind". The variable is initialized to
                          undefined at the start of the function body, and will be assigned
                          a value at its original location in the code. (Actually, it will be assigned a value at every location where a declaration of a variable with the same name occurs.)



                        The order of hoisting is also important: function declarations take precedence over variable declarations with the same name, and the last function declaration takes precedence over previous function declarations with the same name.



                        Some examples...



                        var foo = 1;
                        function bar() {
                        if (!foo) {
                        var foo = 10 }
                        return foo; }
                        bar() // 10


                        Variable foo is hoisted to the top of the function, initialized to undefined, so that !foo is true, so foo is assigned 10. The foo outside of bar's scope plays no role and is untouched.



                        function f() {
                        return a;
                        function a() {return 1};
                        var a = 4;
                        function a() {return 2}}
                        f()() // 2

                        function f() {
                        return a;
                        var a = 4;
                        function a() {return 1};
                        function a() {return 2}}
                        f()() // 2


                        Function declarations take precedence over variable declarations, and the last function declaration "sticks".



                        function f() {
                        var a = 4;
                        function a() {return 1};
                        function a() {return 2};
                        return a; }
                        f() // 4


                        In this example a is initialized with the function object resulting from evaluating the second function declaration, and then is assigned 4.



                        var a = 1;
                        function b() {
                        a = 10;
                        return;
                        function a() {}}
                        b();
                        a // 1


                        Here the function declaration is hoisted first, declaring and initializing variable a. Next, this variable is assigned 10. In other words: the assignment does not assign to outer variable a.






                        share|improve this answer

















                        • 2




                          You have a bit weird way to place the closing braces. Are you a Python coder? It looks like you try to make Javascript look like Python. I am afraid it is confusing for other people. If I had to maintain your JavaScript code I would let your code through an automatic prettyprinter first.
                          – nalply
                          May 14 '13 at 12:46






                        • 1




                          Excellent post. A 'self-executing function' or 'immediately invoked function expression' should be easy enough to see and his style preference should not detract from his post - which is accurate and summarizes 'hoisting' perfectly. +1
                          – Ricalsin
                          Dec 17 '13 at 18:13
















                        32














                        A function declaration and a function expression assigned to a variable behave the same once the binding is established.



                        There is a difference however at how and when the function object is actually associated with its variable. This difference is due to the mechanism called variable hoisting in JavaScript.



                        Basically, all function declarations and variable declarations are hoisted to the top of the function in which the declaration occurs (this is why we say that JavaScript has function scope).




                        • When a function declaration is hoisted, the function body "follows"
                          so when the function body is evaluated, the variable will immediately
                          be bound to a function object.


                        • When a variable declaration is hoisted, the initialization does not
                          follow, but is "left behind". The variable is initialized to
                          undefined at the start of the function body, and will be assigned
                          a value at its original location in the code. (Actually, it will be assigned a value at every location where a declaration of a variable with the same name occurs.)



                        The order of hoisting is also important: function declarations take precedence over variable declarations with the same name, and the last function declaration takes precedence over previous function declarations with the same name.



                        Some examples...



                        var foo = 1;
                        function bar() {
                        if (!foo) {
                        var foo = 10 }
                        return foo; }
                        bar() // 10


                        Variable foo is hoisted to the top of the function, initialized to undefined, so that !foo is true, so foo is assigned 10. The foo outside of bar's scope plays no role and is untouched.



                        function f() {
                        return a;
                        function a() {return 1};
                        var a = 4;
                        function a() {return 2}}
                        f()() // 2

                        function f() {
                        return a;
                        var a = 4;
                        function a() {return 1};
                        function a() {return 2}}
                        f()() // 2


                        Function declarations take precedence over variable declarations, and the last function declaration "sticks".



                        function f() {
                        var a = 4;
                        function a() {return 1};
                        function a() {return 2};
                        return a; }
                        f() // 4


                        In this example a is initialized with the function object resulting from evaluating the second function declaration, and then is assigned 4.



                        var a = 1;
                        function b() {
                        a = 10;
                        return;
                        function a() {}}
                        b();
                        a // 1


                        Here the function declaration is hoisted first, declaring and initializing variable a. Next, this variable is assigned 10. In other words: the assignment does not assign to outer variable a.






                        share|improve this answer

















                        • 2




                          You have a bit weird way to place the closing braces. Are you a Python coder? It looks like you try to make Javascript look like Python. I am afraid it is confusing for other people. If I had to maintain your JavaScript code I would let your code through an automatic prettyprinter first.
                          – nalply
                          May 14 '13 at 12:46






                        • 1




                          Excellent post. A 'self-executing function' or 'immediately invoked function expression' should be easy enough to see and his style preference should not detract from his post - which is accurate and summarizes 'hoisting' perfectly. +1
                          – Ricalsin
                          Dec 17 '13 at 18:13














                        32












                        32








                        32






                        A function declaration and a function expression assigned to a variable behave the same once the binding is established.



                        There is a difference however at how and when the function object is actually associated with its variable. This difference is due to the mechanism called variable hoisting in JavaScript.



                        Basically, all function declarations and variable declarations are hoisted to the top of the function in which the declaration occurs (this is why we say that JavaScript has function scope).




                        • When a function declaration is hoisted, the function body "follows"
                          so when the function body is evaluated, the variable will immediately
                          be bound to a function object.


                        • When a variable declaration is hoisted, the initialization does not
                          follow, but is "left behind". The variable is initialized to
                          undefined at the start of the function body, and will be assigned
                          a value at its original location in the code. (Actually, it will be assigned a value at every location where a declaration of a variable with the same name occurs.)



                        The order of hoisting is also important: function declarations take precedence over variable declarations with the same name, and the last function declaration takes precedence over previous function declarations with the same name.



                        Some examples...



                        var foo = 1;
                        function bar() {
                        if (!foo) {
                        var foo = 10 }
                        return foo; }
                        bar() // 10


                        Variable foo is hoisted to the top of the function, initialized to undefined, so that !foo is true, so foo is assigned 10. The foo outside of bar's scope plays no role and is untouched.



                        function f() {
                        return a;
                        function a() {return 1};
                        var a = 4;
                        function a() {return 2}}
                        f()() // 2

                        function f() {
                        return a;
                        var a = 4;
                        function a() {return 1};
                        function a() {return 2}}
                        f()() // 2


                        Function declarations take precedence over variable declarations, and the last function declaration "sticks".



                        function f() {
                        var a = 4;
                        function a() {return 1};
                        function a() {return 2};
                        return a; }
                        f() // 4


                        In this example a is initialized with the function object resulting from evaluating the second function declaration, and then is assigned 4.



                        var a = 1;
                        function b() {
                        a = 10;
                        return;
                        function a() {}}
                        b();
                        a // 1


                        Here the function declaration is hoisted first, declaring and initializing variable a. Next, this variable is assigned 10. In other words: the assignment does not assign to outer variable a.






                        share|improve this answer












                        A function declaration and a function expression assigned to a variable behave the same once the binding is established.



                        There is a difference however at how and when the function object is actually associated with its variable. This difference is due to the mechanism called variable hoisting in JavaScript.



                        Basically, all function declarations and variable declarations are hoisted to the top of the function in which the declaration occurs (this is why we say that JavaScript has function scope).




                        • When a function declaration is hoisted, the function body "follows"
                          so when the function body is evaluated, the variable will immediately
                          be bound to a function object.


                        • When a variable declaration is hoisted, the initialization does not
                          follow, but is "left behind". The variable is initialized to
                          undefined at the start of the function body, and will be assigned
                          a value at its original location in the code. (Actually, it will be assigned a value at every location where a declaration of a variable with the same name occurs.)



                        The order of hoisting is also important: function declarations take precedence over variable declarations with the same name, and the last function declaration takes precedence over previous function declarations with the same name.



                        Some examples...



                        var foo = 1;
                        function bar() {
                        if (!foo) {
                        var foo = 10 }
                        return foo; }
                        bar() // 10


                        Variable foo is hoisted to the top of the function, initialized to undefined, so that !foo is true, so foo is assigned 10. The foo outside of bar's scope plays no role and is untouched.



                        function f() {
                        return a;
                        function a() {return 1};
                        var a = 4;
                        function a() {return 2}}
                        f()() // 2

                        function f() {
                        return a;
                        var a = 4;
                        function a() {return 1};
                        function a() {return 2}}
                        f()() // 2


                        Function declarations take precedence over variable declarations, and the last function declaration "sticks".



                        function f() {
                        var a = 4;
                        function a() {return 1};
                        function a() {return 2};
                        return a; }
                        f() // 4


                        In this example a is initialized with the function object resulting from evaluating the second function declaration, and then is assigned 4.



                        var a = 1;
                        function b() {
                        a = 10;
                        return;
                        function a() {}}
                        b();
                        a // 1


                        Here the function declaration is hoisted first, declaring and initializing variable a. Next, this variable is assigned 10. In other words: the assignment does not assign to outer variable a.







                        share|improve this answer












                        share|improve this answer



                        share|improve this answer










                        answered Feb 6 '13 at 16:29









                        eljenso

                        12k54762




                        12k54762








                        • 2




                          You have a bit weird way to place the closing braces. Are you a Python coder? It looks like you try to make Javascript look like Python. I am afraid it is confusing for other people. If I had to maintain your JavaScript code I would let your code through an automatic prettyprinter first.
                          – nalply
                          May 14 '13 at 12:46






                        • 1




                          Excellent post. A 'self-executing function' or 'immediately invoked function expression' should be easy enough to see and his style preference should not detract from his post - which is accurate and summarizes 'hoisting' perfectly. +1
                          – Ricalsin
                          Dec 17 '13 at 18:13














                        • 2




                          You have a bit weird way to place the closing braces. Are you a Python coder? It looks like you try to make Javascript look like Python. I am afraid it is confusing for other people. If I had to maintain your JavaScript code I would let your code through an automatic prettyprinter first.
                          – nalply
                          May 14 '13 at 12:46






                        • 1




                          Excellent post. A 'self-executing function' or 'immediately invoked function expression' should be easy enough to see and his style preference should not detract from his post - which is accurate and summarizes 'hoisting' perfectly. +1
                          – Ricalsin
                          Dec 17 '13 at 18:13








                        2




                        2




                        You have a bit weird way to place the closing braces. Are you a Python coder? It looks like you try to make Javascript look like Python. I am afraid it is confusing for other people. If I had to maintain your JavaScript code I would let your code through an automatic prettyprinter first.
                        – nalply
                        May 14 '13 at 12:46




                        You have a bit weird way to place the closing braces. Are you a Python coder? It looks like you try to make Javascript look like Python. I am afraid it is confusing for other people. If I had to maintain your JavaScript code I would let your code through an automatic prettyprinter first.
                        – nalply
                        May 14 '13 at 12:46




                        1




                        1




                        Excellent post. A 'self-executing function' or 'immediately invoked function expression' should be easy enough to see and his style preference should not detract from his post - which is accurate and summarizes 'hoisting' perfectly. +1
                        – Ricalsin
                        Dec 17 '13 at 18:13




                        Excellent post. A 'self-executing function' or 'immediately invoked function expression' should be easy enough to see and his style preference should not detract from his post - which is accurate and summarizes 'hoisting' perfectly. +1
                        – Ricalsin
                        Dec 17 '13 at 18:13











                        30














                        The first example is a function declaration:



                        function abc(){}


                        The second example is a function expression:



                        var abc = function() {};


                        The main difference is how they are hoisted (lifted and declared). In the first example, the whole function declaration is hoisted. In the second example only the var 'abc' is hoisted, its value (the function) will be undefined, and the function itself remains at the position that it is declared.



                        To put it simply:



                        //this will work
                        abc(param);
                        function abc(){}

                        //this would fail
                        abc(param);
                        var abc = function() {}


                        To study more about this topic I strongly recommend you this
                        link






                        share|improve this answer



















                        • 1




                          Your example is kind of the same as the top answer
                          – GôTô
                          Jun 5 '14 at 8:34










                        • The main reason for posting this answer was to provide the link at the bottom. This was the piece that was missing for me to fully understand the above question.
                          – sla55er
                          Jun 8 '14 at 5:44






                        • 1




                          It's very cool that you wanted to share the link. But links to additional information, in SO, should just be a comment on either the question or your favorite answer. It's very much sub-optimal to clutter a long, complicated page like this with repeated information just to add a single useful link at the end of it. No, you won't get rep points for providing the link, but you'll be helping the community.
                          – XML
                          Jan 13 '15 at 0:26
















                        30














                        The first example is a function declaration:



                        function abc(){}


                        The second example is a function expression:



                        var abc = function() {};


                        The main difference is how they are hoisted (lifted and declared). In the first example, the whole function declaration is hoisted. In the second example only the var 'abc' is hoisted, its value (the function) will be undefined, and the function itself remains at the position that it is declared.



                        To put it simply:



                        //this will work
                        abc(param);
                        function abc(){}

                        //this would fail
                        abc(param);
                        var abc = function() {}


                        To study more about this topic I strongly recommend you this
                        link






                        share|improve this answer



















                        • 1




                          Your example is kind of the same as the top answer
                          – GôTô
                          Jun 5 '14 at 8:34










                        • The main reason for posting this answer was to provide the link at the bottom. This was the piece that was missing for me to fully understand the above question.
                          – sla55er
                          Jun 8 '14 at 5:44






                        • 1




                          It's very cool that you wanted to share the link. But links to additional information, in SO, should just be a comment on either the question or your favorite answer. It's very much sub-optimal to clutter a long, complicated page like this with repeated information just to add a single useful link at the end of it. No, you won't get rep points for providing the link, but you'll be helping the community.
                          – XML
                          Jan 13 '15 at 0:26














                        30












                        30








                        30






                        The first example is a function declaration:



                        function abc(){}


                        The second example is a function expression:



                        var abc = function() {};


                        The main difference is how they are hoisted (lifted and declared). In the first example, the whole function declaration is hoisted. In the second example only the var 'abc' is hoisted, its value (the function) will be undefined, and the function itself remains at the position that it is declared.



                        To put it simply:



                        //this will work
                        abc(param);
                        function abc(){}

                        //this would fail
                        abc(param);
                        var abc = function() {}


                        To study more about this topic I strongly recommend you this
                        link






                        share|improve this answer














                        The first example is a function declaration:



                        function abc(){}


                        The second example is a function expression:



                        var abc = function() {};


                        The main difference is how they are hoisted (lifted and declared). In the first example, the whole function declaration is hoisted. In the second example only the var 'abc' is hoisted, its value (the function) will be undefined, and the function itself remains at the position that it is declared.



                        To put it simply:



                        //this will work
                        abc(param);
                        function abc(){}

                        //this would fail
                        abc(param);
                        var abc = function() {}


                        To study more about this topic I strongly recommend you this
                        link







                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited May 9 '15 at 9:37

























                        answered Jun 5 '14 at 8:28









                        sla55er

                        5411616




                        5411616








                        • 1




                          Your example is kind of the same as the top answer
                          – GôTô
                          Jun 5 '14 at 8:34










                        • The main reason for posting this answer was to provide the link at the bottom. This was the piece that was missing for me to fully understand the above question.
                          – sla55er
                          Jun 8 '14 at 5:44






                        • 1




                          It's very cool that you wanted to share the link. But links to additional information, in SO, should just be a comment on either the question or your favorite answer. It's very much sub-optimal to clutter a long, complicated page like this with repeated information just to add a single useful link at the end of it. No, you won't get rep points for providing the link, but you'll be helping the community.
                          – XML
                          Jan 13 '15 at 0:26














                        • 1




                          Your example is kind of the same as the top answer
                          – GôTô
                          Jun 5 '14 at 8:34










                        • The main reason for posting this answer was to provide the link at the bottom. This was the piece that was missing for me to fully understand the above question.
                          – sla55er
                          Jun 8 '14 at 5:44






                        • 1




                          It's very cool that you wanted to share the link. But links to additional information, in SO, should just be a comment on either the question or your favorite answer. It's very much sub-optimal to clutter a long, complicated page like this with repeated information just to add a single useful link at the end of it. No, you won't get rep points for providing the link, but you'll be helping the community.
                          – XML
                          Jan 13 '15 at 0:26








                        1




                        1




                        Your example is kind of the same as the top answer
                        – GôTô
                        Jun 5 '14 at 8:34




                        Your example is kind of the same as the top answer
                        – GôTô
                        Jun 5 '14 at 8:34












                        The main reason for posting this answer was to provide the link at the bottom. This was the piece that was missing for me to fully understand the above question.
                        – sla55er
                        Jun 8 '14 at 5:44




                        The main reason for posting this answer was to provide the link at the bottom. This was the piece that was missing for me to fully understand the above question.
                        – sla55er
                        Jun 8 '14 at 5:44




                        1




                        1




                        It's very cool that you wanted to share the link. But links to additional information, in SO, should just be a comment on either the question or your favorite answer. It's very much sub-optimal to clutter a long, complicated page like this with repeated information just to add a single useful link at the end of it. No, you won't get rep points for providing the link, but you'll be helping the community.
                        – XML
                        Jan 13 '15 at 0:26




                        It's very cool that you wanted to share the link. But links to additional information, in SO, should just be a comment on either the question or your favorite answer. It's very much sub-optimal to clutter a long, complicated page like this with repeated information just to add a single useful link at the end of it. No, you won't get rep points for providing the link, but you'll be helping the community.
                        – XML
                        Jan 13 '15 at 0:26











                        28














                        In terms of code maintenance cost, named functions are more preferable:




                        • Independent from the place where they are declared (but still limited by scope).

                        • More resistant to mistakes like conditional initialization (you are still able to override if wanted to).

                        • The code becomes more readable by allocating local functions separately of scope functionality. Usually in the scope the functionality goes first, followed by declarations of local functions.

                        • In a debugger you will clearly see the function name on the call stack instead of an "anonymous/evaluated" function.


                        I suspect more PROS for named functions are follow. And what is listed as an advantage of named functions is a disadvantage for anonymous ones.



                        Historically, anonymous functions appeared from the inability of JavaScript as a language to list members with named functions:



                        {
                        member:function() { /* How do I make "this.member" a named function? */
                        }
                        }





                        share|improve this answer



















                        • 2




                          There are the test to confirm: blog.firsov.net/2010/01/… JS performance test - scope and named functions - Analytics
                          – Sasha Firsov
                          Feb 4 '10 at 0:45


















                        28














                        In terms of code maintenance cost, named functions are more preferable:




                        • Independent from the place where they are declared (but still limited by scope).

                        • More resistant to mistakes like conditional initialization (you are still able to override if wanted to).

                        • The code becomes more readable by allocating local functions separately of scope functionality. Usually in the scope the functionality goes first, followed by declarations of local functions.

                        • In a debugger you will clearly see the function name on the call stack instead of an "anonymous/evaluated" function.


                        I suspect more PROS for named functions are follow. And what is listed as an advantage of named functions is a disadvantage for anonymous ones.



                        Historically, anonymous functions appeared from the inability of JavaScript as a language to list members with named functions:



                        {
                        member:function() { /* How do I make "this.member" a named function? */
                        }
                        }





                        share|improve this answer



















                        • 2




                          There are the test to confirm: blog.firsov.net/2010/01/… JS performance test - scope and named functions - Analytics
                          – Sasha Firsov
                          Feb 4 '10 at 0:45
















                        28












                        28








                        28






                        In terms of code maintenance cost, named functions are more preferable:




                        • Independent from the place where they are declared (but still limited by scope).

                        • More resistant to mistakes like conditional initialization (you are still able to override if wanted to).

                        • The code becomes more readable by allocating local functions separately of scope functionality. Usually in the scope the functionality goes first, followed by declarations of local functions.

                        • In a debugger you will clearly see the function name on the call stack instead of an "anonymous/evaluated" function.


                        I suspect more PROS for named functions are follow. And what is listed as an advantage of named functions is a disadvantage for anonymous ones.



                        Historically, anonymous functions appeared from the inability of JavaScript as a language to list members with named functions:



                        {
                        member:function() { /* How do I make "this.member" a named function? */
                        }
                        }





                        share|improve this answer














                        In terms of code maintenance cost, named functions are more preferable:




                        • Independent from the place where they are declared (but still limited by scope).

                        • More resistant to mistakes like conditional initialization (you are still able to override if wanted to).

                        • The code becomes more readable by allocating local functions separately of scope functionality. Usually in the scope the functionality goes first, followed by declarations of local functions.

                        • In a debugger you will clearly see the function name on the call stack instead of an "anonymous/evaluated" function.


                        I suspect more PROS for named functions are follow. And what is listed as an advantage of named functions is a disadvantage for anonymous ones.



                        Historically, anonymous functions appeared from the inability of JavaScript as a language to list members with named functions:



                        {
                        member:function() { /* How do I make "this.member" a named function? */
                        }
                        }






                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited Dec 28 '15 at 19:44









                        Peter Mortensen

                        13.5k1983111




                        13.5k1983111










                        answered Jan 23 '10 at 20:32









                        Sasha Firsov

                        46266




                        46266








                        • 2




                          There are the test to confirm: blog.firsov.net/2010/01/… JS performance test - scope and named functions - Analytics
                          – Sasha Firsov
                          Feb 4 '10 at 0:45
















                        • 2




                          There are the test to confirm: blog.firsov.net/2010/01/… JS performance test - scope and named functions - Analytics
                          – Sasha Firsov
                          Feb 4 '10 at 0:45










                        2




                        2




                        There are the test to confirm: blog.firsov.net/2010/01/… JS performance test - scope and named functions - Analytics
                        – Sasha Firsov
                        Feb 4 '10 at 0:45






                        There are the test to confirm: blog.firsov.net/2010/01/… JS performance test - scope and named functions - Analytics
                        – Sasha Firsov
                        Feb 4 '10 at 0:45













                        24














                        I use the variable approach in my code for a very specific reason, the theory of which has been covered in an abstract way above, but an example might help some people like me, with limited JavaScript expertise.



                        I have code that I need to run with 160 independently-designed brandings. Most of the code is in shared files, but branding-specific stuff is in a separate file, one for each branding.



                        Some brandings require specific functions, and some do not. Sometimes I have to add new functions to do new branding-specific things. I am happy to change the shared coded, but I don't want to have to change all 160 sets of branding files.



                        By using the variable syntax, I can declare the variable (a function pointer essentially) in the shared code and either assign a trivial stub function, or set to null.



                        The one or two brandings that need a specific implementation of the function can then define their version of the function and assign this to the variable if they want, and the rest do nothing. I can test for a null function before I execute it in the shared code.



                        From people's comments above, I gather it may be possible to redefine a static function too, but I think the variable solution is nice and clear.






                        share|improve this answer




























                          24














                          I use the variable approach in my code for a very specific reason, the theory of which has been covered in an abstract way above, but an example might help some people like me, with limited JavaScript expertise.



                          I have code that I need to run with 160 independently-designed brandings. Most of the code is in shared files, but branding-specific stuff is in a separate file, one for each branding.



                          Some brandings require specific functions, and some do not. Sometimes I have to add new functions to do new branding-specific things. I am happy to change the shared coded, but I don't want to have to change all 160 sets of branding files.



                          By using the variable syntax, I can declare the variable (a function pointer essentially) in the shared code and either assign a trivial stub function, or set to null.



                          The one or two brandings that need a specific implementation of the function can then define their version of the function and assign this to the variable if they want, and the rest do nothing. I can test for a null function before I execute it in the shared code.



                          From people's comments above, I gather it may be possible to redefine a static function too, but I think the variable solution is nice and clear.






                          share|improve this answer


























                            24












                            24








                            24






                            I use the variable approach in my code for a very specific reason, the theory of which has been covered in an abstract way above, but an example might help some people like me, with limited JavaScript expertise.



                            I have code that I need to run with 160 independently-designed brandings. Most of the code is in shared files, but branding-specific stuff is in a separate file, one for each branding.



                            Some brandings require specific functions, and some do not. Sometimes I have to add new functions to do new branding-specific things. I am happy to change the shared coded, but I don't want to have to change all 160 sets of branding files.



                            By using the variable syntax, I can declare the variable (a function pointer essentially) in the shared code and either assign a trivial stub function, or set to null.



                            The one or two brandings that need a specific implementation of the function can then define their version of the function and assign this to the variable if they want, and the rest do nothing. I can test for a null function before I execute it in the shared code.



                            From people's comments above, I gather it may be possible to redefine a static function too, but I think the variable solution is nice and clear.






                            share|improve this answer














                            I use the variable approach in my code for a very specific reason, the theory of which has been covered in an abstract way above, but an example might help some people like me, with limited JavaScript expertise.



                            I have code that I need to run with 160 independently-designed brandings. Most of the code is in shared files, but branding-specific stuff is in a separate file, one for each branding.



                            Some brandings require specific functions, and some do not. Sometimes I have to add new functions to do new branding-specific things. I am happy to change the shared coded, but I don't want to have to change all 160 sets of branding files.



                            By using the variable syntax, I can declare the variable (a function pointer essentially) in the shared code and either assign a trivial stub function, or set to null.



                            The one or two brandings that need a specific implementation of the function can then define their version of the function and assign this to the variable if they want, and the rest do nothing. I can test for a null function before I execute it in the shared code.



                            From people's comments above, I gather it may be possible to redefine a static function too, but I think the variable solution is nice and clear.







                            share|improve this answer














                            share|improve this answer



                            share|improve this answer








                            edited Dec 28 '15 at 20:26









                            Peter Mortensen

                            13.5k1983111




                            13.5k1983111










                            answered Nov 29 '12 at 11:28









                            Herc

                            42739




                            42739























                                22














                                In computer science terms, we talk about anonymous functions and named functions. I think the most important difference is that an anonymous function is not bound to an name, hence the name anonymous function. In JavaScript it is a first class object dynamically declared at runtime.



                                For more information on anonymous functions and lambda calculus, Wikipedia is a good start (http://en.wikipedia.org/wiki/Anonymous_function).






                                share|improve this answer




























                                  22














                                  In computer science terms, we talk about anonymous functions and named functions. I think the most important difference is that an anonymous function is not bound to an name, hence the name anonymous function. In JavaScript it is a first class object dynamically declared at runtime.



                                  For more information on anonymous functions and lambda calculus, Wikipedia is a good start (http://en.wikipedia.org/wiki/Anonymous_function).






                                  share|improve this answer


























                                    22












                                    22








                                    22






                                    In computer science terms, we talk about anonymous functions and named functions. I think the most important difference is that an anonymous function is not bound to an name, hence the name anonymous function. In JavaScript it is a first class object dynamically declared at runtime.



                                    For more information on anonymous functions and lambda calculus, Wikipedia is a good start (http://en.wikipedia.org/wiki/Anonymous_function).






                                    share|improve this answer














                                    In computer science terms, we talk about anonymous functions and named functions. I think the most important difference is that an anonymous function is not bound to an name, hence the name anonymous function. In JavaScript it is a first class object dynamically declared at runtime.



                                    For more information on anonymous functions and lambda calculus, Wikipedia is a good start (http://en.wikipedia.org/wiki/Anonymous_function).







                                    share|improve this answer














                                    share|improve this answer



                                    share|improve this answer








                                    edited Oct 19 '14 at 22:25









                                    ROMANIA_engineer

                                    32.8k19144141




                                    32.8k19144141










                                    answered Dec 18 '08 at 19:30









                                    Kafka

                                    38214




                                    38214























                                        22














                                        Greg's Answer is good enough, but I still would like to add something to it that I learned just now watching Douglas Crockford's videos.



                                        Function expression:



                                        var foo = function foo() {};


                                        Function statement:



                                        function foo() {};


                                        The function statement is just a shorthand for var statement with a function value.



                                        So



                                        function foo() {};


                                        expands to



                                        var foo = function foo() {};


                                        Which expands further to:



                                        var foo = undefined;
                                        foo = function foo() {};


                                        And they are both hoisted to the top of the code.



                                        Screenshot from video






                                        share|improve this answer



















                                        • 7




                                          Sorry but this is incorrect - I don't know what Crockford is trying to say in that slide. Both function & variable declarations are always hoisted to top of their scope. The difference is that variable assignments (whether you are assigning it with a string, boolean or function) are not hoisted to the top whereas function bodies (using function declaration) are.
                                          – Thomas Heymann
                                          Oct 5 '15 at 16:25












                                        • Have a look at these code examples: gist.github.com/cyberthom/36603fbc20de8e04fd09
                                          – Thomas Heymann
                                          Oct 5 '15 at 16:51


















                                        22














                                        Greg's Answer is good enough, but I still would like to add something to it that I learned just now watching Douglas Crockford's videos.



                                        Function expression:



                                        var foo = function foo() {};


                                        Function statement:



                                        function foo() {};


                                        The function statement is just a shorthand for var statement with a function value.



                                        So



                                        function foo() {};


                                        expands to



                                        var foo = function foo() {};


                                        Which expands further to:



                                        var foo = undefined;
                                        foo = function foo() {};


                                        And they are both hoisted to the top of the code.



                                        Screenshot from video






                                        share|improve this answer



















                                        • 7




                                          Sorry but this is incorrect - I don't know what Crockford is trying to say in that slide. Both function & variable declarations are always hoisted to top of their scope. The difference is that variable assignments (whether you are assigning it with a string, boolean or function) are not hoisted to the top whereas function bodies (using function declaration) are.
                                          – Thomas Heymann
                                          Oct 5 '15 at 16:25












                                        • Have a look at these code examples: gist.github.com/cyberthom/36603fbc20de8e04fd09
                                          – Thomas Heymann
                                          Oct 5 '15 at 16:51
















                                        22












                                        22








                                        22






                                        Greg's Answer is good enough, but I still would like to add something to it that I learned just now watching Douglas Crockford's videos.



                                        Function expression:



                                        var foo = function foo() {};


                                        Function statement:



                                        function foo() {};


                                        The function statement is just a shorthand for var statement with a function value.



                                        So



                                        function foo() {};


                                        expands to



                                        var foo = function foo() {};


                                        Which expands further to:



                                        var foo = undefined;
                                        foo = function foo() {};


                                        And they are both hoisted to the top of the code.



                                        Screenshot from video






                                        share|improve this answer














                                        Greg's Answer is good enough, but I still would like to add something to it that I learned just now watching Douglas Crockford's videos.



                                        Function expression:



                                        var foo = function foo() {};


                                        Function statement:



                                        function foo() {};


                                        The function statement is just a shorthand for var statement with a function value.



                                        So



                                        function foo() {};


                                        expands to



                                        var foo = function foo() {};


                                        Which expands further to:



                                        var foo = undefined;
                                        foo = function foo() {};


                                        And they are both hoisted to the top of the code.



                                        Screenshot from video







                                        share|improve this answer














                                        share|improve this answer



                                        share|improve this answer








                                        edited May 23 '17 at 12:18









                                        Community

                                        11




                                        11










                                        answered Jul 21 '15 at 7:45









                                        Rohan

                                        4,493114495




                                        4,493114495








                                        • 7




                                          Sorry but this is incorrect - I don't know what Crockford is trying to say in that slide. Both function & variable declarations are always hoisted to top of their scope. The difference is that variable assignments (whether you are assigning it with a string, boolean or function) are not hoisted to the top whereas function bodies (using function declaration) are.
                                          – Thomas Heymann
                                          Oct 5 '15 at 16:25












                                        • Have a look at these code examples: gist.github.com/cyberthom/36603fbc20de8e04fd09
                                          – Thomas Heymann
                                          Oct 5 '15 at 16:51
















                                        • 7




                                          Sorry but this is incorrect - I don't know what Crockford is trying to say in that slide. Both function & variable declarations are always hoisted to top of their scope. The difference is that variable assignments (whether you are assigning it with a string, boolean or function) are not hoisted to the top whereas function bodies (using function declaration) are.
                                          – Thomas Heymann
                                          Oct 5 '15 at 16:25












                                        • Have a look at these code examples: gist.github.com/cyberthom/36603fbc20de8e04fd09
                                          – Thomas Heymann
                                          Oct 5 '15 at 16:51










                                        7




                                        7




                                        Sorry but this is incorrect - I don't know what Crockford is trying to say in that slide. Both function & variable declarations are always hoisted to top of their scope. The difference is that variable assignments (whether you are assigning it with a string, boolean or function) are not hoisted to the top whereas function bodies (using function declaration) are.
                                        – Thomas Heymann
                                        Oct 5 '15 at 16:25






                                        Sorry but this is incorrect - I don't know what Crockford is trying to say in that slide. Both function & variable declarations are always hoisted to top of their scope. The difference is that variable assignments (whether you are assigning it with a string, boolean or function) are not hoisted to the top whereas function bodies (using function declaration) are.
                                        – Thomas Heymann
                                        Oct 5 '15 at 16:25














                                        Have a look at these code examples: gist.github.com/cyberthom/36603fbc20de8e04fd09
                                        – Thomas Heymann
                                        Oct 5 '15 at 16:51






                                        Have a look at these code examples: gist.github.com/cyberthom/36603fbc20de8e04fd09
                                        – Thomas Heymann
                                        Oct 5 '15 at 16:51













                                        18














                                        @EugeneLazutkin gives an example where he names an assigned function to be able to use shortcut() as an internal reference to itself. John Resig gives another example - copying a recursive function assigned to another object in his Learning Advanced Javascript tutorial. While assigning functions to properties isn't strictly the question here, I recommend actively trying the tutorial out - run the code by clicking the button in the upper right corner, and double click the code to edit to your liking.



                                        Examples from the tutorial: recursive calls in yell():



                                        Tests fail when the original ninja object is removed. (page 13)



                                        var ninja = { 
                                        yell: function(n){
                                        return n > 0 ? ninja.yell(n-1) + "a" : "hiy";
                                        }
                                        };
                                        assert( ninja.yell(4) == "hiyaaaa", "A single object isn't too bad, either." );

                                        var samurai = { yell: ninja.yell };
                                        var ninja = null;

                                        try {
                                        samurai.yell(4);
                                        } catch(e){
                                        assert( false, "Uh, this isn't good! Where'd ninja.yell go?" );
                                        }


                                        If you name the function that will be called recursively, the tests will pass. (page 14)



                                        var ninja = { 
                                        yell: function yell(n){
                                        return n > 0 ? yell(n-1) + "a" : "hiy";
                                        }
                                        };
                                        assert( ninja.yell(4) == "hiyaaaa", "Works as we would expect it to!" );

                                        var samurai = { yell: ninja.yell };
                                        var ninja = {};
                                        assert( samurai.yell(4) == "hiyaaaa", "The method correctly calls itself." );





                                        share|improve this answer























                                        • Just calling this.yell works too :)
                                          – Ry-
                                          Apr 21 '13 at 20:54
















                                        18














                                        @EugeneLazutkin gives an example where he names an assigned function to be able to use shortcut() as an internal reference to itself. John Resig gives another example - copying a recursive function assigned to another object in his Learning Advanced Javascript tutorial. While assigning functions to properties isn't strictly the question here, I recommend actively trying the tutorial out - run the code by clicking the button in the upper right corner, and double click the code to edit to your liking.



                                        Examples from the tutorial: recursive calls in yell():



                                        Tests fail when the original ninja object is removed. (page 13)



                                        var ninja = { 
                                        yell: function(n){
                                        return n > 0 ? ninja.yell(n-1) + "a" : "hiy";
                                        }
                                        };
                                        assert( ninja.yell(4) == "hiyaaaa", "A single object isn't too bad, either." );

                                        var samurai = { yell: ninja.yell };
                                        var ninja = null;

                                        try {
                                        samurai.yell(4);
                                        } catch(e){
                                        assert( false, "Uh, this isn't good! Where'd ninja.yell go?" );
                                        }


                                        If you name the function that will be called recursively, the tests will pass. (page 14)



                                        var ninja = { 
                                        yell: function yell(n){
                                        return n > 0 ? yell(n-1) + "a" : "hiy";
                                        }
                                        };
                                        assert( ninja.yell(4) == "hiyaaaa", "Works as we would expect it to!" );

                                        var samurai = { yell: ninja.yell };
                                        var ninja = {};
                                        assert( samurai.yell(4) == "hiyaaaa", "The method correctly calls itself." );





                                        share|improve this answer























                                        • Just calling this.yell works too :)
                                          – Ry-
                                          Apr 21 '13 at 20:54














                                        18












                                        18








                                        18






                                        @EugeneLazutkin gives an example where he names an assigned function to be able to use shortcut() as an internal reference to itself. John Resig gives another example - copying a recursive function assigned to another object in his Learning Advanced Javascript tutorial. While assigning functions to properties isn't strictly the question here, I recommend actively trying the tutorial out - run the code by clicking the button in the upper right corner, and double click the code to edit to your liking.



                                        Examples from the tutorial: recursive calls in yell():



                                        Tests fail when the original ninja object is removed. (page 13)



                                        var ninja = { 
                                        yell: function(n){
                                        return n > 0 ? ninja.yell(n-1) + "a" : "hiy";
                                        }
                                        };
                                        assert( ninja.yell(4) == "hiyaaaa", "A single object isn't too bad, either." );

                                        var samurai = { yell: ninja.yell };
                                        var ninja = null;

                                        try {
                                        samurai.yell(4);
                                        } catch(e){
                                        assert( false, "Uh, this isn't good! Where'd ninja.yell go?" );
                                        }


                                        If you name the function that will be called recursively, the tests will pass. (page 14)



                                        var ninja = { 
                                        yell: function yell(n){
                                        return n > 0 ? yell(n-1) + "a" : "hiy";
                                        }
                                        };
                                        assert( ninja.yell(4) == "hiyaaaa", "Works as we would expect it to!" );

                                        var samurai = { yell: ninja.yell };
                                        var ninja = {};
                                        assert( samurai.yell(4) == "hiyaaaa", "The method correctly calls itself." );





                                        share|improve this answer














                                        @EugeneLazutkin gives an example where he names an assigned function to be able to use shortcut() as an internal reference to itself. John Resig gives another example - copying a recursive function assigned to another object in his Learning Advanced Javascript tutorial. While assigning functions to properties isn't strictly the question here, I recommend actively trying the tutorial out - run the code by clicking the button in the upper right corner, and double click the code to edit to your liking.



                                        Examples from the tutorial: recursive calls in yell():



                                        Tests fail when the original ninja object is removed. (page 13)



                                        var ninja = { 
                                        yell: function(n){
                                        return n > 0 ? ninja.yell(n-1) + "a" : "hiy";
                                        }
                                        };
                                        assert( ninja.yell(4) == "hiyaaaa", "A single object isn't too bad, either." );

                                        var samurai = { yell: ninja.yell };
                                        var ninja = null;

                                        try {
                                        samurai.yell(4);
                                        } catch(e){
                                        assert( false, "Uh, this isn't good! Where'd ninja.yell go?" );
                                        }


                                        If you name the function that will be called recursively, the tests will pass. (page 14)



                                        var ninja = { 
                                        yell: function yell(n){
                                        return n > 0 ? yell(n-1) + "a" : "hiy";
                                        }
                                        };
                                        assert( ninja.yell(4) == "hiyaaaa", "Works as we would expect it to!" );

                                        var samurai = { yell: ninja.yell };
                                        var ninja = {};
                                        assert( samurai.yell(4) == "hiyaaaa", "The method correctly calls itself." );






                                        share|improve this answer














                                        share|improve this answer



                                        share|improve this answer








                                        edited May 23 '17 at 12:34









                                        Community

                                        11




                                        11










                                        answered Aug 4 '12 at 15:24









                                        Joel Purra

                                        16.8k74755




                                        16.8k74755












                                        • Just calling this.yell works too :)
                                          – Ry-
                                          Apr 21 '13 at 20:54


















                                        • Just calling this.yell works too :)
                                          – Ry-
                                          Apr 21 '13 at 20:54
















                                        Just calling this.yell works too :)
                                        – Ry-
                                        Apr 21 '13 at 20:54




                                        Just calling this.yell works too :)
                                        – Ry-
                                        Apr 21 '13 at 20:54











                                        15














                                        Another difference that is not mentioned in the other answers is that if you use the anonymous function



                                        var functionOne = function() {
                                        // Some code
                                        };


                                        and use that as a constructor as in



                                        var one = new functionOne();


                                        then one.constructor.name will not be defined. Function.name is non-standard but is supported by Firefox, Chrome, other Webkit-derived browsers and IE 9+.



                                        With



                                        function functionTwo() {
                                        // Some code
                                        }
                                        two = new functionTwo();


                                        it is possible to retrieve the name of the constructor as a string with two.constructor.name.






                                        share|improve this answer























                                        • The name in the first case will not be defined because its an anonymous function assigned to a variable. I think the word anonymous was invented for things that don't have their name defined :)
                                          – Om Shankar
                                          Jan 17 '13 at 6:13










                                        • In this example the two=new becomes a global function because no var
                                          – Waqas Tahir
                                          Aug 29 '15 at 5:04
















                                        15














                                        Another difference that is not mentioned in the other answers is that if you use the anonymous function



                                        var functionOne = function() {
                                        // Some code
                                        };


                                        and use that as a constructor as in



                                        var one = new functionOne();


                                        then one.constructor.name will not be defined. Function.name is non-standard but is supported by Firefox, Chrome, other Webkit-derived browsers and IE 9+.



                                        With



                                        function functionTwo() {
                                        // Some code
                                        }
                                        two = new functionTwo();


                                        it is possible to retrieve the name of the constructor as a string with two.constructor.name.






                                        share|improve this answer























                                        • The name in the first case will not be defined because its an anonymous function assigned to a variable. I think the word anonymous was invented for things that don't have their name defined :)
                                          – Om Shankar
                                          Jan 17 '13 at 6:13










                                        • In this example the two=new becomes a global function because no var
                                          – Waqas Tahir
                                          Aug 29 '15 at 5:04














                                        15












                                        15








                                        15






                                        Another difference that is not mentioned in the other answers is that if you use the anonymous function



                                        var functionOne = function() {
                                        // Some code
                                        };


                                        and use that as a constructor as in



                                        var one = new functionOne();


                                        then one.constructor.name will not be defined. Function.name is non-standard but is supported by Firefox, Chrome, other Webkit-derived browsers and IE 9+.



                                        With



                                        function functionTwo() {
                                        // Some code
                                        }
                                        two = new functionTwo();


                                        it is possible to retrieve the name of the constructor as a string with two.constructor.name.






                                        share|improve this answer














                                        Another difference that is not mentioned in the other answers is that if you use the anonymous function



                                        var functionOne = function() {
                                        // Some code
                                        };


                                        and use that as a constructor as in



                                        var one = new functionOne();


                                        then one.constructor.name will not be defined. Function.name is non-standard but is supported by Firefox, Chrome, other Webkit-derived browsers and IE 9+.



                                        With



                                        function functionTwo() {
                                        // Some code
                                        }
                                        two = new functionTwo();


                                        it is possible to retrieve the name of the constructor as a string with two.constructor.name.







                                        share|improve this answer














                                        share|improve this answer



                                        share|improve this answer








                                        edited Jan 17 '13 at 8:48

























                                        answered Oct 15 '12 at 10:42









                                        Ingo Kegel

                                        34.1k75183




                                        34.1k75183












                                        • The name in the first case will not be defined because its an anonymous function assigned to a variable. I think the word anonymous was invented for things that don't have their name defined :)
                                          – Om Shankar
                                          Jan 17 '13 at 6:13










                                        • In this example the two=new becomes a global function because no var
                                          – Waqas Tahir
                                          Aug 29 '15 at 5:04


















                                        • The name in the first case will not be defined because its an anonymous function assigned to a variable. I think the word anonymous was invented for things that don't have their name defined :)
                                          – Om Shankar
                                          Jan 17 '13 at 6:13










                                        • In this example the two=new becomes a global function because no var
                                          – Waqas Tahir
                                          Aug 29 '15 at 5:04
















                                        The name in the first case will not be defined because its an anonymous function assigned to a variable. I think the word anonymous was invented for things that don't have their name defined :)
                                        – Om Shankar
                                        Jan 17 '13 at 6:13




                                        The name in the first case will not be defined because its an anonymous function assigned to a variable. I think the word anonymous was invented for things that don't have their name defined :)
                                        – Om Shankar
                                        Jan 17 '13 at 6:13












                                        In this example the two=new becomes a global function because no var
                                        – Waqas Tahir
                                        Aug 29 '15 at 5:04




                                        In this example the two=new becomes a global function because no var
                                        – Waqas Tahir
                                        Aug 29 '15 at 5:04











                                        14














                                        If you would use those functions to create objects, you would get:



                                        var objectOne = new functionOne();
                                        console.log(objectOne.__proto__); // prints "Object {}" because constructor is an anonymous function

                                        var objectTwo = new functionTwo();
                                        console.log(objectTwo.__proto__); // prints "functionTwo {}" because constructor is a named function





                                        share|improve this answer





















                                        • I can't seem to reproduce this. console.log(objectOne.__proto__); prints "functionOne {}" in my console. Any ideas of why this may be the case?
                                          – Mike
                                          Mar 22 '15 at 10:06












                                        • I can't seem to reproduce it as well.
                                          – daremkd
                                          Jan 21 '16 at 15:57






                                        • 1




                                          This is a capability of your debugger (to display the "class" of the logged object), and most ones are able to derive a name even for anonymous function expressions these days. Btw, you should make clear that there is no functional difference between the two instances.
                                          – Bergi
                                          Jan 21 '16 at 16:26
















                                        14














                                        If you would use those functions to create objects, you would get:



                                        var objectOne = new functionOne();
                                        console.log(objectOne.__proto__); // prints "Object {}" because constructor is an anonymous function

                                        var objectTwo = new functionTwo();
                                        console.log(objectTwo.__proto__); // prints "functionTwo {}" because constructor is a named function





                                        share|improve this answer





















                                        • I can't seem to reproduce this. console.log(objectOne.__proto__); prints "functionOne {}" in my console. Any ideas of why this may be the case?
                                          – Mike
                                          Mar 22 '15 at 10:06












                                        • I can't seem to reproduce it as well.
                                          – daremkd
                                          Jan 21 '16 at 15:57






                                        • 1




                                          This is a capability of your debugger (to display the "class" of the logged object), and most ones are able to derive a name even for anonymous function expressions these days. Btw, you should make clear that there is no functional difference between the two instances.
                                          – Bergi
                                          Jan 21 '16 at 16:26














                                        14












                                        14








                                        14






                                        If you would use those functions to create objects, you would get:



                                        var objectOne = new functionOne();
                                        console.log(objectOne.__proto__); // prints "Object {}" because constructor is an anonymous function

                                        var objectTwo = new functionTwo();
                                        console.log(objectTwo.__proto__); // prints "functionTwo {}" because constructor is a named function





                                        share|improve this answer












                                        If you would use those functions to create objects, you would get:



                                        var objectOne = new functionOne();
                                        console.log(objectOne.__proto__); // prints "Object {}" because constructor is an anonymous function

                                        var objectTwo = new functionTwo();
                                        console.log(objectTwo.__proto__); // prints "functionTwo {}" because constructor is a named function






                                        share|improve this answer












                                        share|improve this answer



                                        share|improve this answer










                                        answered Oct 25 '13 at 16:38









                                        Pawel Furmaniak

                                        2,70032232




                                        2,70032232












                                        • I can't seem to reproduce this. console.log(objectOne.__proto__); prints "functionOne {}" in my console. Any ideas of why this may be the case?
                                          – Mike
                                          Mar 22 '15 at 10:06












                                        • I can't seem to reproduce it as well.
                                          – daremkd
                                          Jan 21 '16 at 15:57






                                        • 1




                                          This is a capability of your debugger (to display the "class" of the logged object), and most ones are able to derive a name even for anonymous function expressions these days. Btw, you should make clear that there is no functional difference between the two instances.
                                          – Bergi
                                          Jan 21 '16 at 16:26


















                                        • I can't seem to reproduce this. console.log(objectOne.__proto__); prints "functionOne {}" in my console. Any ideas of why this may be the case?
                                          – Mike
                                          Mar 22 '15 at 10:06












                                        • I can't seem to reproduce it as well.
                                          – daremkd
                                          Jan 21 '16 at 15:57






                                        • 1




                                          This is a capability of your debugger (to display the "class" of the logged object), and most ones are able to derive a name even for anonymous function expressions these days. Btw, you should make clear that there is no functional difference between the two instances.
                                          – Bergi
                                          Jan 21 '16 at 16:26
















                                        I can't seem to reproduce this. console.log(objectOne.__proto__); prints "functionOne {}" in my console. Any ideas of why this may be the case?
                                        – Mike
                                        Mar 22 '15 at 10:06






                                        I can't seem to reproduce this. console.log(objectOne.__proto__); prints "functionOne {}" in my console. Any ideas of why this may be the case?
                                        – Mike
                                        Mar 22 '15 at 10:06














                                        I can't seem to reproduce it as well.
                                        – daremkd
                                        Jan 21 '16 at 15:57




                                        I can't seem to reproduce it as well.
                                        – daremkd
                                        Jan 21 '16 at 15:57




                                        1




                                        1




                                        This is a capability of your debugger (to display the "class" of the logged object), and most ones are able to derive a name even for anonymous function expressions these days. Btw, you should make clear that there is no functional difference between the two instances.
                                        – Bergi
                                        Jan 21 '16 at 16:26




                                        This is a capability of your debugger (to display the "class" of the logged object), and most ones are able to derive a name even for anonymous function expressions these days. Btw, you should make clear that there is no functional difference between the two instances.
                                        – Bergi
                                        Jan 21 '16 at 16:26











                                        14














                                        The first one (function doSomething(x)) should be part of an object notation.



                                        The second one (var doSomething = function(x){ alert(x);}) is simply creating an anonymous function and assigning it to a variable, doSomething. So doSomething() will call the function.



                                        You may want to know what a function declaration and function expression is.



                                        A function declaration defines a named function variable without requiring variable assignment. Function declarations occur as standalone constructs and cannot be nested within non-function blocks.



                                        function foo() {
                                        return 3;
                                        }



                                        ECMA 5 (13.0) defines the syntax as

                                        function Identifier ( FormalParameterListopt ) { FunctionBody }




                                        In above condition the function name is visible within its scope and the scope of its parent (otherwise it would be unreachable).



                                        And in a function expression



                                        A function expression defines a function as a part of a larger expression syntax (typically a variable assignment ). Functions defined via functions expressions can be named or anonymous. Function expressions should not start with “function”.



                                        // Anonymous function expression
                                        var a = function() {
                                        return 3;
                                        }

                                        // Named function expression
                                        var a = function foo() {
                                        return 3;
                                        }

                                        // Self-invoking function expression
                                        (function foo() {
                                        alert("hello!");
                                        })();



                                        ECMA 5 (13.0) defines the syntax as

                                        function Identifieropt ( FormalParameterListopt ) { FunctionBody }







                                        share|improve this answer




























                                          14














                                          The first one (function doSomething(x)) should be part of an object notation.



                                          The second one (var doSomething = function(x){ alert(x);}) is simply creating an anonymous function and assigning it to a variable, doSomething. So doSomething() will call the function.



                                          You may want to know what a function declaration and function expression is.



                                          A function declaration defines a named function variable without requiring variable assignment. Function declarations occur as standalone constructs and cannot be nested within non-function blocks.



                                          function foo() {
                                          return 3;
                                          }



                                          ECMA 5 (13.0) defines the syntax as

                                          function Identifier ( FormalParameterListopt ) { FunctionBody }




                                          In above condition the function name is visible within its scope and the scope of its parent (otherwise it would be unreachable).



                                          And in a function expression



                                          A function expression defines a function as a part of a larger expression syntax (typically a variable assignment ). Functions defined via functions expressions can be named or anonymous. Function expressions should not start with “function”.



                                          // Anonymous function expression
                                          var a = function() {
                                          return 3;
                                          }

                                          // Named function expression
                                          var a = function foo() {
                                          return 3;
                                          }

                                          // Self-invoking function expression
                                          (function foo() {
                                          alert("hello!");
                                          })();



                                          ECMA 5 (13.0) defines the syntax as

                                          function Identifieropt ( FormalParameterListopt ) { FunctionBody }







                                          share|improve this answer


























                                            14












                                            14








                                            14






                                            The first one (function doSomething(x)) should be part of an object notation.



                                            The second one (var doSomething = function(x){ alert(x);}) is simply creating an anonymous function and assigning it to a variable, doSomething. So doSomething() will call the function.



                                            You may want to know what a function declaration and function expression is.



                                            A function declaration defines a named function variable without requiring variable assignment. Function declarations occur as standalone constructs and cannot be nested within non-function blocks.



                                            function foo() {
                                            return 3;
                                            }



                                            ECMA 5 (13.0) defines the syntax as

                                            function Identifier ( FormalParameterListopt ) { FunctionBody }




                                            In above condition the function name is visible within its scope and the scope of its parent (otherwise it would be unreachable).



                                            And in a function expression



                                            A function expression defines a function as a part of a larger expression syntax (typically a variable assignment ). Functions defined via functions expressions can be named or anonymous. Function expressions should not start with “function”.



                                            // Anonymous function expression
                                            var a = function() {
                                            return 3;
                                            }

                                            // Named function expression
                                            var a = function foo() {
                                            return 3;
                                            }

                                            // Self-invoking function expression
                                            (function foo() {
                                            alert("hello!");
                                            })();



                                            ECMA 5 (13.0) defines the syntax as

                                            function Identifieropt ( FormalParameterListopt ) { FunctionBody }







                                            share|improve this answer














                                            The first one (function doSomething(x)) should be part of an object notation.



                                            The second one (var doSomething = function(x){ alert(x);}) is simply creating an anonymous function and assigning it to a variable, doSomething. So doSomething() will call the function.



                                            You may want to know what a function declaration and function expression is.



                                            A function declaration defines a named function variable without requiring variable assignment. Function declarations occur as standalone constructs and cannot be nested within non-function blocks.



                                            function foo() {
                                            return 3;
                                            }



                                            ECMA 5 (13.0) defines the syntax as

                                            function Identifier ( FormalParameterListopt ) { FunctionBody }




                                            In above condition the function name is visible within its scope and the scope of its parent (otherwise it would be unreachable).



                                            And in a function expression



                                            A function expression defines a function as a part of a larger expression syntax (typically a variable assignment ). Functions defined via functions expressions can be named or anonymous. Function expressions should not start with “function”.



                                            // Anonymous function expression
                                            var a = function() {
                                            return 3;
                                            }

                                            // Named function expression
                                            var a = function foo() {
                                            return 3;
                                            }

                                            // Self-invoking function expression
                                            (function foo() {
                                            alert("hello!");
                                            })();



                                            ECMA 5 (13.0) defines the syntax as

                                            function Identifieropt ( FormalParameterListopt ) { FunctionBody }








                                            share|improve this answer














                                            share|improve this answer



                                            share|improve this answer








                                            edited Dec 28 '15 at 20:29









                                            Peter Mortensen

                                            13.5k1983111




                                            13.5k1983111










                                            answered Jan 5 '13 at 18:37









                                            NullPoiиteя

                                            45.2k17106125




                                            45.2k17106125























                                                14














                                                I'm listing out the differences below:





                                                1. A function declaration can be placed anywhere in the code. Even if it is invoked before the definition appears in code, it gets executed as function declaration is committed to memory or in a way it is hoisted up, before any other code in the page starts execution.



                                                  Take a look at the function below:



                                                  function outerFunction() {
                                                  function foo() {
                                                  return 1;
                                                  }
                                                  return foo();
                                                  function foo() {
                                                  return 2;
                                                  }
                                                  }
                                                  alert(outerFunction()); // Displays 2


                                                  This is because, during execution, it looks like:-



                                                  function foo() {  // The first function declaration is moved to top
                                                  return 1;
                                                  }
                                                  function foo() { // The second function declaration is moved to top
                                                  return 2;
                                                  }
                                                  function outerFunction() {
                                                  return foo();
                                                  }
                                                  alert(outerFunction()); //So executing from top to bottom,
                                                  //the last foo() returns 2 which gets displayed


                                                  A function expression, if not defined before calling it, will result in an error. Also, here the function definition itself is not moved to the top or committed to memory like in the function declarations. But the variable to which we assign the function gets hoisted up and undefined gets assigned to it.



                                                  Same function using function expressions:



                                                  function outerFunction() {
                                                  var foo = function() {
                                                  return 1;
                                                  }
                                                  return foo();
                                                  var foo = function() {
                                                  return 2;
                                                  }
                                                  }
                                                  alert(outerFunction()); // Displays 1


                                                  This is because during execution, it looks like:



                                                  function outerFunction() {
                                                  var foo = undefined;
                                                  var foo = undefined;

                                                  foo = function() {
                                                  return 1;
                                                  };
                                                  return foo ();
                                                  foo = function() { // This function expression is not reachable
                                                  return 2;
                                                  };
                                                  }
                                                  alert(outerFunction()); // Displays 1



                                                2. It is not safe to write function declarations in non-function blocks like if because they won't be accessible.



                                                  if (test) {
                                                  function x() { doSomething(); }
                                                  }



                                                3. Named function expression like the one below, may not work in Internet Explorer browsers prior to version 9.



                                                  var today = function today() {return new Date()}







                                                share|improve this answer



















                                                • 1




                                                  @Arjun What's the problem if a question was asked years earlier ? An answer doesn't only benefit the OP but potentially all SO users, no matter when the question was asked. And what's wrong with answering questions that already have an accepted answer ?
                                                  – SantiBailors
                                                  Oct 5 '15 at 12:58






                                                • 1




                                                  @Arjun you got to understand answering old questions is not bad. If it were to be, SO would have had such a barrier. Imagine there is a change in API(albeit not in this question's context) and someone spots it and provides an answer with the new API, shouldn't that be allowed?? Until and unless the answer doesn't make sense and doesn't belong here, it would be downvoted and removed automatically. You don't need to bother with it!!!!
                                                  – Sudhansu Choudhary
                                                  Oct 18 '15 at 21:37
















                                                14














                                                I'm listing out the differences below:





                                                1. A function declaration can be placed anywhere in the code. Even if it is invoked before the definition appears in code, it gets executed as function declaration is committed to memory or in a way it is hoisted up, before any other code in the page starts execution.



                                                  Take a look at the function below:



                                                  function outerFunction() {
                                                  function foo() {
                                                  return 1;
                                                  }
                                                  return foo();
                                                  function foo() {
                                                  return 2;
                                                  }
                                                  }
                                                  alert(outerFunction()); // Displays 2


                                                  This is because, during execution, it looks like:-



                                                  function foo() {  // The first function declaration is moved to top
                                                  return 1;
                                                  }
                                                  function foo() { // The second function declaration is moved to top
                                                  return 2;
                                                  }
                                                  function outerFunction() {
                                                  return foo();
                                                  }
                                                  alert(outerFunction()); //So executing from top to bottom,
                                                  //the last foo() returns 2 which gets displayed


                                                  A function expression, if not defined before calling it, will result in an error. Also, here the function definition itself is not moved to the top or committed to memory like in the function declarations. But the variable to which we assign the function gets hoisted up and undefined gets assigned to it.



                                                  Same function using function expressions:



                                                  function outerFunction() {
                                                  var foo = function() {
                                                  return 1;
                                                  }
                                                  return foo();
                                                  var foo = function() {
                                                  return 2;
                                                  }
                                                  }
                                                  alert(outerFunction()); // Displays 1


                                                  This is because during execution, it looks like:



                                                  function outerFunction() {
                                                  var foo = undefined;
                                                  var foo = undefined;

                                                  foo = function() {
                                                  return 1;
                                                  };
                                                  return foo ();
                                                  foo = function() { // This function expression is not reachable
                                                  return 2;
                                                  };
                                                  }
                                                  alert(outerFunction()); // Displays 1



                                                2. It is not safe to write function declarations in non-function blocks like if because they won't be accessible.



                                                  if (test) {
                                                  function x() { doSomething(); }
                                                  }



                                                3. Named function expression like the one below, may not work in Internet Explorer browsers prior to version 9.



                                                  var today = function today() {return new Date()}







                                                share|improve this answer



















                                                • 1




                                                  @Arjun What's the problem if a question was asked years earlier ? An answer doesn't only benefit the OP but potentially all SO users, no matter when the question was asked. And what's wrong with answering questions that already have an accepted answer ?
                                                  – SantiBailors
                                                  Oct 5 '15 at 12:58






                                                • 1




                                                  @Arjun you got to understand answering old questions is not bad. If it were to be, SO would have had such a barrier. Imagine there is a change in API(albeit not in this question's context) and someone spots it and provides an answer with the new API, shouldn't that be allowed?? Until and unless the answer doesn't make sense and doesn't belong here, it would be downvoted and removed automatically. You don't need to bother with it!!!!
                                                  – Sudhansu Choudhary
                                                  Oct 18 '15 at 21:37














                                                14












                                                14








                                                14






                                                I'm listing out the differences below:





                                                1. A function declaration can be placed anywhere in the code. Even if it is invoked before the definition appears in code, it gets executed as function declaration is committed to memory or in a way it is hoisted up, before any other code in the page starts execution.



                                                  Take a look at the function below:



                                                  function outerFunction() {
                                                  function foo() {
                                                  return 1;
                                                  }
                                                  return foo();
                                                  function foo() {
                                                  return 2;
                                                  }
                                                  }
                                                  alert(outerFunction()); // Displays 2


                                                  This is because, during execution, it looks like:-



                                                  function foo() {  // The first function declaration is moved to top
                                                  return 1;
                                                  }
                                                  function foo() { // The second function declaration is moved to top
                                                  return 2;
                                                  }
                                                  function outerFunction() {
                                                  return foo();
                                                  }
                                                  alert(outerFunction()); //So executing from top to bottom,
                                                  //the last foo() returns 2 which gets displayed


                                                  A function expression, if not defined before calling it, will result in an error. Also, here the function definition itself is not moved to the top or committed to memory like in the function declarations. But the variable to which we assign the function gets hoisted up and undefined gets assigned to it.



                                                  Same function using function expressions:



                                                  function outerFunction() {
                                                  var foo = function() {
                                                  return 1;
                                                  }
                                                  return foo();
                                                  var foo = function() {
                                                  return 2;
                                                  }
                                                  }
                                                  alert(outerFunction()); // Displays 1


                                                  This is because during execution, it looks like:



                                                  function outerFunction() {
                                                  var foo = undefined;
                                                  var foo = undefined;

                                                  foo = function() {
                                                  return 1;
                                                  };
                                                  return foo ();
                                                  foo = function() { // This function expression is not reachable
                                                  return 2;
                                                  };
                                                  }
                                                  alert(outerFunction()); // Displays 1



                                                2. It is not safe to write function declarations in non-function blocks like if because they won't be accessible.



                                                  if (test) {
                                                  function x() { doSomething(); }
                                                  }



                                                3. Named function expression like the one below, may not work in Internet Explorer browsers prior to version 9.



                                                  var today = function today() {return new Date()}







                                                share|improve this answer














                                                I'm listing out the differences below:





                                                1. A function declaration can be placed anywhere in the code. Even if it is invoked before the definition appears in code, it gets executed as function declaration is committed to memory or in a way it is hoisted up, before any other code in the page starts execution.



                                                  Take a look at the function below:



                                                  function outerFunction() {
                                                  function foo() {
                                                  return 1;
                                                  }
                                                  return foo();
                                                  function foo() {
                                                  return 2;
                                                  }
                                                  }
                                                  alert(outerFunction()); // Displays 2


                                                  This is because, during execution, it looks like:-



                                                  function foo() {  // The first function declaration is moved to top
                                                  return 1;
                                                  }
                                                  function foo() { // The second function declaration is moved to top
                                                  return 2;
                                                  }
                                                  function outerFunction() {
                                                  return foo();
                                                  }
                                                  alert(outerFunction()); //So executing from top to bottom,
                                                  //the last foo() returns 2 which gets displayed


                                                  A function expression, if not defined before calling it, will result in an error. Also, here the function definition itself is not moved to the top or committed to memory like in the function declarations. But the variable to which we assign the function gets hoisted up and undefined gets assigned to it.



                                                  Same function using function expressions:



                                                  function outerFunction() {
                                                  var foo = function() {
                                                  return 1;
                                                  }
                                                  return foo();
                                                  var foo = function() {
                                                  return 2;
                                                  }
                                                  }
                                                  alert(outerFunction()); // Displays 1


                                                  This is because during execution, it looks like:



                                                  function outerFunction() {
                                                  var foo = undefined;
                                                  var foo = undefined;

                                                  foo = function() {
                                                  return 1;
                                                  };
                                                  return foo ();
                                                  foo = function() { // This function expression is not reachable
                                                  return 2;
                                                  };
                                                  }
                                                  alert(outerFunction()); // Displays 1



                                                2. It is not safe to write function declarations in non-function blocks like if because they won't be accessible.



                                                  if (test) {
                                                  function x() { doSomething(); }
                                                  }



                                                3. Named function expression like the one below, may not work in Internet Explorer browsers prior to version 9.



                                                  var today = function today() {return new Date()}








                                                share|improve this answer














                                                share|improve this answer



                                                share|improve this answer








                                                edited Dec 28 '15 at 20:35









                                                Peter Mortensen

                                                13.5k1983111




                                                13.5k1983111










                                                answered Sep 9 '15 at 10:30









                                                varna

                                                821812




                                                821812








                                                • 1




                                                  @Arjun What's the problem if a question was asked years earlier ? An answer doesn't only benefit the OP but potentially all SO users, no matter when the question was asked. And what's wrong with answering questions that already have an accepted answer ?
                                                  – SantiBailors
                                                  Oct 5 '15 at 12:58






                                                • 1




                                                  @Arjun you got to understand answering old questions is not bad. If it were to be, SO would have had such a barrier. Imagine there is a change in API(albeit not in this question's context) and someone spots it and provides an answer with the new API, shouldn't that be allowed?? Until and unless the answer doesn't make sense and doesn't belong here, it would be downvoted and removed automatically. You don't need to bother with it!!!!
                                                  – Sudhansu Choudhary
                                                  Oct 18 '15 at 21:37














                                                • 1




                                                  @Arjun What's the problem if a question was asked years earlier ? An answer doesn't only benefit the OP but potentially all SO users, no matter when the question was asked. And what's wrong with answering questions that already have an accepted answer ?
                                                  – SantiBailors
                                                  Oct 5 '15 at 12:58






                                                • 1




                                                  @Arjun you got to understand answering old questions is not bad. If it were to be, SO would have had such a barrier. Imagine there is a change in API(albeit not in this question's context) and someone spots it and provides an answer with the new API, shouldn't that be allowed?? Until and unless the answer doesn't make sense and doesn't belong here, it would be downvoted and removed automatically. You don't need to bother with it!!!!
                                                  – Sudhansu Choudhary
                                                  Oct 18 '15 at 21:37








                                                1




                                                1




                                                @Arjun What's the problem if a question was asked years earlier ? An answer doesn't only benefit the OP but potentially all SO users, no matter when the question was asked. And what's wrong with answering questions that already have an accepted answer ?
                                                – SantiBailors
                                                Oct 5 '15 at 12:58




                                                @Arjun What's the problem if a question was asked years earlier ? An answer doesn't only benefit the OP but potentially all SO users, no matter when the question was asked. And what's wrong with answering questions that already have an accepted answer ?
                                                – SantiBailors
                                                Oct 5 '15 at 12:58




                                                1




                                                1




                                                @Arjun you got to understand answering old questions is not bad. If it were to be, SO would have had such a barrier. Imagine there is a change in API(albeit not in this question's context) and someone spots it and provides an answer with the new API, shouldn't that be allowed?? Until and unless the answer doesn't make sense and doesn't belong here, it would be downvoted and removed automatically. You don't need to bother with it!!!!
                                                – Sudhansu Choudhary
                                                Oct 18 '15 at 21:37




                                                @Arjun you got to understand answering old questions is not bad. If it were to be, SO would have had such a barrier. Imagine there is a change in API(albeit not in this question's context) and someone spots it and provides an answer with the new API, shouldn't that be allowed?? Until and unless the answer doesn't make sense and doesn't belong here, it would be downvoted and removed automatically. You don't need to bother with it!!!!
                                                – Sudhansu Choudhary
                                                Oct 18 '15 at 21:37











                                                12














                                                In light of the "named functions show up in stack traces" argument, modern JavaScript engines are actually quite capable of representing anonymous functions.



                                                As of this writing, V8, SpiderMonkey, Chakra and Nitro always refer to named functions by their names. They almost always refer to an anonymous function by its identifier if it has one.



                                                SpiderMonkey can figure out the name of an anonymous function returned from another function. The rest can't.



                                                If you really, really wanted your iterator and success callbacks to show up in the trace, you could name those too...



                                                .forEach(function iterator() {});


                                                But for the most part it's not worth stressing over.



                                                Harness (Fiddle)



                                                'use strict';

                                                var a = function () {
                                                throw new Error();
                                                },
                                                b = function b() {
                                                throw new Error();
                                                },
                                                c = function d() {
                                                throw new Error();
                                                },
                                                e = {
                                                f: a,
                                                g: b,
                                                h: c,
                                                i: function () {
                                                throw new Error();
                                                },
                                                j: function j() {
                                                throw new Error();
                                                },
                                                k: function l() {
                                                throw new Error();
                                                }
                                                },
                                                m = (function () {
                                                return function () {
                                                throw new Error();
                                                };
                                                }()),
                                                n = (function () {
                                                return function n() {
                                                throw new Error();
                                                };
                                                }()),
                                                o = (function () {
                                                return function p() {
                                                throw new Error();
                                                };
                                                }());

                                                console.log([a, b, c].concat(Object.keys(e).reduce(function (values, key) {
                                                return values.concat(e[key]);
                                                }, )).concat([m, n, o]).reduce(function (logs, func) {

                                                try {
                                                func();
                                                } catch (error) {
                                                return logs.concat('func.name: ' + func.name + 'n' +
                                                'Trace:n' +
                                                error.stack);
                                                // Need to manually log the error object in Nitro.
                                                }

                                                }, ).join('nn'));


                                                V8



                                                func.name: 
                                                Trace:
                                                Error
                                                at a (http://localhost:8000/test.js:4:11)
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27

                                                func.name: b
                                                Trace:
                                                Error
                                                at b (http://localhost:8000/test.js:7:15)
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27

                                                func.name: d
                                                Trace:
                                                Error
                                                at d (http://localhost:8000/test.js:10:15)
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27

                                                func.name:
                                                Trace:
                                                Error
                                                at a (http://localhost:8000/test.js:4:11)
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27

                                                func.name: b
                                                Trace:
                                                Error
                                                at b (http://localhost:8000/test.js:7:15)
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27

                                                func.name: d
                                                Trace:
                                                Error
                                                at d (http://localhost:8000/test.js:10:15)
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27

                                                func.name:
                                                Trace:
                                                Error
                                                at e.i (http://localhost:8000/test.js:17:19)
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27

                                                func.name: j
                                                Trace:
                                                Error
                                                at j (http://localhost:8000/test.js:20:19)
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27

                                                func.name: l
                                                Trace:
                                                Error
                                                at l (http://localhost:8000/test.js:23:19)
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27

                                                func.name:
                                                Trace:
                                                Error
                                                at http://localhost:8000/test.js:28:19
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27

                                                func.name: n
                                                Trace:
                                                Error
                                                at n (http://localhost:8000/test.js:33:19)
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27

                                                func.name: p
                                                Trace:
                                                Error
                                                at p (http://localhost:8000/test.js:38:19)
                                                at http://localhost:8000/test.js:47:9
                                                at Array.reduce (native)
                                                at http://localhost:8000/test.js:44:27 test.js:42


                                                SpiderMonkey



                                                func.name: 
                                                Trace:
                                                a@http://localhost:8000/test.js:4:5
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                func.name: b
                                                Trace:
                                                b@http://localhost:8000/test.js:7:9
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                func.name: d
                                                Trace:
                                                d@http://localhost:8000/test.js:10:9
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                func.name:
                                                Trace:
                                                a@http://localhost:8000/test.js:4:5
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                func.name: b
                                                Trace:
                                                b@http://localhost:8000/test.js:7:9
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                func.name: d
                                                Trace:
                                                d@http://localhost:8000/test.js:10:9
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                func.name:
                                                Trace:
                                                e.i@http://localhost:8000/test.js:17:13
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                func.name: j
                                                Trace:
                                                j@http://localhost:8000/test.js:20:13
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                func.name: l
                                                Trace:
                                                l@http://localhost:8000/test.js:23:13
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                func.name:
                                                Trace:
                                                m</<@http://localhost:8000/test.js:28:13
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                func.name: n
                                                Trace:
                                                n@http://localhost:8000/test.js:33:13
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                func.name: p
                                                Trace:
                                                p@http://localhost:8000/test.js:38:13
                                                @http://localhost:8000/test.js:47:9
                                                @http://localhost:8000/test.js:54:1


                                                Chakra



                                                func.name: undefined
                                                Trace:
                                                Error
                                                at a (http://localhost:8000/test.js:4:5)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                func.name: undefined
                                                Trace:
                                                Error
                                                at b (http://localhost:8000/test.js:7:9)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                func.name: undefined
                                                Trace:
                                                Error
                                                at d (http://localhost:8000/test.js:10:9)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                func.name: undefined
                                                Trace:
                                                Error
                                                at a (http://localhost:8000/test.js:4:5)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                func.name: undefined
                                                Trace:
                                                Error
                                                at b (http://localhost:8000/test.js:7:9)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                func.name: undefined
                                                Trace:
                                                Error
                                                at d (http://localhost:8000/test.js:10:9)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                func.name: undefined
                                                Trace:
                                                Error
                                                at e.i (http://localhost:8000/test.js:17:13)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                func.name: undefined
                                                Trace:
                                                Error
                                                at j (http://localhost:8000/test.js:20:13)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                func.name: undefined
                                                Trace:
                                                Error
                                                at l (http://localhost:8000/test.js:23:13)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                func.name: undefined
                                                Trace:
                                                Error
                                                at Anonymous function (http://localhost:8000/test.js:28:13)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                func.name: undefined
                                                Trace:
                                                Error
                                                at n (http://localhost:8000/test.js:33:13)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                func.name: undefined
                                                Trace:
                                                Error
                                                at p (http://localhost:8000/test.js:38:13)
                                                at Anonymous function (http://localhost:8000/test.js:47:9)
                                                at Global code (http://localhost:8000/test.js:42:1)


                                                Nitro



                                                func.name: 
                                                Trace:
                                                a@http://localhost:8000/test.js:4:22
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33

                                                func.name: b
                                                Trace:
                                                b@http://localhost:8000/test.js:7:26
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33

                                                func.name: d
                                                Trace:
                                                d@http://localhost:8000/test.js:10:26
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33

                                                func.name:
                                                Trace:
                                                a@http://localhost:8000/test.js:4:22
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33

                                                func.name: b
                                                Trace:
                                                b@http://localhost:8000/test.js:7:26
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33

                                                func.name: d
                                                Trace:
                                                d@http://localhost:8000/test.js:10:26
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33

                                                func.name:
                                                Trace:
                                                i@http://localhost:8000/test.js:17:30
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33

                                                func.name: j
                                                Trace:
                                                j@http://localhost:8000/test.js:20:30
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33

                                                func.name: l
                                                Trace:
                                                l@http://localhost:8000/test.js:23:30
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33

                                                func.name:
                                                Trace:
                                                http://localhost:8000/test.js:28:30
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33

                                                func.name: n
                                                Trace:
                                                n@http://localhost:8000/test.js:33:30
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33

                                                func.name: p
                                                Trace:
                                                p@http://localhost:8000/test.js:38:30
                                                http://localhost:8000/test.js:47:13
                                                reduce@[native code]
                                                global code@http://localhost:8000/test.js:44:33





                                                share|improve this answer




























                                                  12














                                                  In light of the "named functions show up in stack traces" argument, modern JavaScript engines are actually quite capable of representing anonymous functions.



                                                  As of this writing, V8, SpiderMonkey, Chakra and Nitro always refer to named functions by their names. They almost always refer to an anonymous function by its identifier if it has one.



                                                  SpiderMonkey can figure out the name of an anonymous function returned from another function. The rest can't.



                                                  If you really, really wanted your iterator and success callbacks to show up in the trace, you could name those too...



                                                  .forEach(function iterator() {});


                                                  But for the most part it's not worth stressing over.



                                                  Harness (Fiddle)



                                                  'use strict';

                                                  var a = function () {
                                                  throw new Error();
                                                  },
                                                  b = function b() {
                                                  throw new Error();
                                                  },
                                                  c = function d() {
                                                  throw new Error();
                                                  },
                                                  e = {
                                                  f: a,
                                                  g: b,
                                                  h: c,
                                                  i: function () {
                                                  throw new Error();
                                                  },
                                                  j: function j() {
                                                  throw new Error();
                                                  },
                                                  k: function l() {
                                                  throw new Error();
                                                  }
                                                  },
                                                  m = (function () {
                                                  return function () {
                                                  throw new Error();
                                                  };
                                                  }()),
                                                  n = (function () {
                                                  return function n() {
                                                  throw new Error();
                                                  };
                                                  }()),
                                                  o = (function () {
                                                  return function p() {
                                                  throw new Error();
                                                  };
                                                  }());

                                                  console.log([a, b, c].concat(Object.keys(e).reduce(function (values, key) {
                                                  return values.concat(e[key]);
                                                  }, )).concat([m, n, o]).reduce(function (logs, func) {

                                                  try {
                                                  func();
                                                  } catch (error) {
                                                  return logs.concat('func.name: ' + func.name + 'n' +
                                                  'Trace:n' +
                                                  error.stack);
                                                  // Need to manually log the error object in Nitro.
                                                  }

                                                  }, ).join('nn'));


                                                  V8



                                                  func.name: 
                                                  Trace:
                                                  Error
                                                  at a (http://localhost:8000/test.js:4:11)
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27

                                                  func.name: b
                                                  Trace:
                                                  Error
                                                  at b (http://localhost:8000/test.js:7:15)
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27

                                                  func.name: d
                                                  Trace:
                                                  Error
                                                  at d (http://localhost:8000/test.js:10:15)
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27

                                                  func.name:
                                                  Trace:
                                                  Error
                                                  at a (http://localhost:8000/test.js:4:11)
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27

                                                  func.name: b
                                                  Trace:
                                                  Error
                                                  at b (http://localhost:8000/test.js:7:15)
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27

                                                  func.name: d
                                                  Trace:
                                                  Error
                                                  at d (http://localhost:8000/test.js:10:15)
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27

                                                  func.name:
                                                  Trace:
                                                  Error
                                                  at e.i (http://localhost:8000/test.js:17:19)
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27

                                                  func.name: j
                                                  Trace:
                                                  Error
                                                  at j (http://localhost:8000/test.js:20:19)
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27

                                                  func.name: l
                                                  Trace:
                                                  Error
                                                  at l (http://localhost:8000/test.js:23:19)
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27

                                                  func.name:
                                                  Trace:
                                                  Error
                                                  at http://localhost:8000/test.js:28:19
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27

                                                  func.name: n
                                                  Trace:
                                                  Error
                                                  at n (http://localhost:8000/test.js:33:19)
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27

                                                  func.name: p
                                                  Trace:
                                                  Error
                                                  at p (http://localhost:8000/test.js:38:19)
                                                  at http://localhost:8000/test.js:47:9
                                                  at Array.reduce (native)
                                                  at http://localhost:8000/test.js:44:27 test.js:42


                                                  SpiderMonkey



                                                  func.name: 
                                                  Trace:
                                                  a@http://localhost:8000/test.js:4:5
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  func.name: b
                                                  Trace:
                                                  b@http://localhost:8000/test.js:7:9
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  func.name: d
                                                  Trace:
                                                  d@http://localhost:8000/test.js:10:9
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  func.name:
                                                  Trace:
                                                  a@http://localhost:8000/test.js:4:5
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  func.name: b
                                                  Trace:
                                                  b@http://localhost:8000/test.js:7:9
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  func.name: d
                                                  Trace:
                                                  d@http://localhost:8000/test.js:10:9
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  func.name:
                                                  Trace:
                                                  e.i@http://localhost:8000/test.js:17:13
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  func.name: j
                                                  Trace:
                                                  j@http://localhost:8000/test.js:20:13
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  func.name: l
                                                  Trace:
                                                  l@http://localhost:8000/test.js:23:13
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  func.name:
                                                  Trace:
                                                  m</<@http://localhost:8000/test.js:28:13
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  func.name: n
                                                  Trace:
                                                  n@http://localhost:8000/test.js:33:13
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  func.name: p
                                                  Trace:
                                                  p@http://localhost:8000/test.js:38:13
                                                  @http://localhost:8000/test.js:47:9
                                                  @http://localhost:8000/test.js:54:1


                                                  Chakra



                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at a (http://localhost:8000/test.js:4:5)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at b (http://localhost:8000/test.js:7:9)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at d (http://localhost:8000/test.js:10:9)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at a (http://localhost:8000/test.js:4:5)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at b (http://localhost:8000/test.js:7:9)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at d (http://localhost:8000/test.js:10:9)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at e.i (http://localhost:8000/test.js:17:13)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at j (http://localhost:8000/test.js:20:13)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at l (http://localhost:8000/test.js:23:13)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at Anonymous function (http://localhost:8000/test.js:28:13)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at n (http://localhost:8000/test.js:33:13)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  func.name: undefined
                                                  Trace:
                                                  Error
                                                  at p (http://localhost:8000/test.js:38:13)
                                                  at Anonymous function (http://localhost:8000/test.js:47:9)
                                                  at Global code (http://localhost:8000/test.js:42:1)


                                                  Nitro



                                                  func.name: 
                                                  Trace:
                                                  a@http://localhost:8000/test.js:4:22
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33

                                                  func.name: b
                                                  Trace:
                                                  b@http://localhost:8000/test.js:7:26
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33

                                                  func.name: d
                                                  Trace:
                                                  d@http://localhost:8000/test.js:10:26
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33

                                                  func.name:
                                                  Trace:
                                                  a@http://localhost:8000/test.js:4:22
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33

                                                  func.name: b
                                                  Trace:
                                                  b@http://localhost:8000/test.js:7:26
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33

                                                  func.name: d
                                                  Trace:
                                                  d@http://localhost:8000/test.js:10:26
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33

                                                  func.name:
                                                  Trace:
                                                  i@http://localhost:8000/test.js:17:30
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33

                                                  func.name: j
                                                  Trace:
                                                  j@http://localhost:8000/test.js:20:30
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33

                                                  func.name: l
                                                  Trace:
                                                  l@http://localhost:8000/test.js:23:30
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33

                                                  func.name:
                                                  Trace:
                                                  http://localhost:8000/test.js:28:30
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33

                                                  func.name: n
                                                  Trace:
                                                  n@http://localhost:8000/test.js:33:30
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33

                                                  func.name: p
                                                  Trace:
                                                  p@http://localhost:8000/test.js:38:30
                                                  http://localhost:8000/test.js:47:13
                                                  reduce@[native code]
                                                  global code@http://localhost:8000/test.js:44:33





                                                  share|improve this answer


























                                                    12












                                                    12








                                                    12






                                                    In light of the "named functions show up in stack traces" argument, modern JavaScript engines are actually quite capable of representing anonymous functions.



                                                    As of this writing, V8, SpiderMonkey, Chakra and Nitro always refer to named functions by their names. They almost always refer to an anonymous function by its identifier if it has one.



                                                    SpiderMonkey can figure out the name of an anonymous function returned from another function. The rest can't.



                                                    If you really, really wanted your iterator and success callbacks to show up in the trace, you could name those too...



                                                    .forEach(function iterator() {});


                                                    But for the most part it's not worth stressing over.



                                                    Harness (Fiddle)



                                                    'use strict';

                                                    var a = function () {
                                                    throw new Error();
                                                    },
                                                    b = function b() {
                                                    throw new Error();
                                                    },
                                                    c = function d() {
                                                    throw new Error();
                                                    },
                                                    e = {
                                                    f: a,
                                                    g: b,
                                                    h: c,
                                                    i: function () {
                                                    throw new Error();
                                                    },
                                                    j: function j() {
                                                    throw new Error();
                                                    },
                                                    k: function l() {
                                                    throw new Error();
                                                    }
                                                    },
                                                    m = (function () {
                                                    return function () {
                                                    throw new Error();
                                                    };
                                                    }()),
                                                    n = (function () {
                                                    return function n() {
                                                    throw new Error();
                                                    };
                                                    }()),
                                                    o = (function () {
                                                    return function p() {
                                                    throw new Error();
                                                    };
                                                    }());

                                                    console.log([a, b, c].concat(Object.keys(e).reduce(function (values, key) {
                                                    return values.concat(e[key]);
                                                    }, )).concat([m, n, o]).reduce(function (logs, func) {

                                                    try {
                                                    func();
                                                    } catch (error) {
                                                    return logs.concat('func.name: ' + func.name + 'n' +
                                                    'Trace:n' +
                                                    error.stack);
                                                    // Need to manually log the error object in Nitro.
                                                    }

                                                    }, ).join('nn'));


                                                    V8



                                                    func.name: 
                                                    Trace:
                                                    Error
                                                    at a (http://localhost:8000/test.js:4:11)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: b
                                                    Trace:
                                                    Error
                                                    at b (http://localhost:8000/test.js:7:15)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: d
                                                    Trace:
                                                    Error
                                                    at d (http://localhost:8000/test.js:10:15)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name:
                                                    Trace:
                                                    Error
                                                    at a (http://localhost:8000/test.js:4:11)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: b
                                                    Trace:
                                                    Error
                                                    at b (http://localhost:8000/test.js:7:15)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: d
                                                    Trace:
                                                    Error
                                                    at d (http://localhost:8000/test.js:10:15)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name:
                                                    Trace:
                                                    Error
                                                    at e.i (http://localhost:8000/test.js:17:19)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: j
                                                    Trace:
                                                    Error
                                                    at j (http://localhost:8000/test.js:20:19)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: l
                                                    Trace:
                                                    Error
                                                    at l (http://localhost:8000/test.js:23:19)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name:
                                                    Trace:
                                                    Error
                                                    at http://localhost:8000/test.js:28:19
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: n
                                                    Trace:
                                                    Error
                                                    at n (http://localhost:8000/test.js:33:19)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: p
                                                    Trace:
                                                    Error
                                                    at p (http://localhost:8000/test.js:38:19)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27 test.js:42


                                                    SpiderMonkey



                                                    func.name: 
                                                    Trace:
                                                    a@http://localhost:8000/test.js:4:5
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: b
                                                    Trace:
                                                    b@http://localhost:8000/test.js:7:9
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: d
                                                    Trace:
                                                    d@http://localhost:8000/test.js:10:9
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name:
                                                    Trace:
                                                    a@http://localhost:8000/test.js:4:5
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: b
                                                    Trace:
                                                    b@http://localhost:8000/test.js:7:9
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: d
                                                    Trace:
                                                    d@http://localhost:8000/test.js:10:9
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name:
                                                    Trace:
                                                    e.i@http://localhost:8000/test.js:17:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: j
                                                    Trace:
                                                    j@http://localhost:8000/test.js:20:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: l
                                                    Trace:
                                                    l@http://localhost:8000/test.js:23:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name:
                                                    Trace:
                                                    m</<@http://localhost:8000/test.js:28:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: n
                                                    Trace:
                                                    n@http://localhost:8000/test.js:33:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: p
                                                    Trace:
                                                    p@http://localhost:8000/test.js:38:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    Chakra



                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at a (http://localhost:8000/test.js:4:5)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at b (http://localhost:8000/test.js:7:9)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at d (http://localhost:8000/test.js:10:9)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at a (http://localhost:8000/test.js:4:5)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at b (http://localhost:8000/test.js:7:9)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at d (http://localhost:8000/test.js:10:9)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at e.i (http://localhost:8000/test.js:17:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at j (http://localhost:8000/test.js:20:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at l (http://localhost:8000/test.js:23:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at Anonymous function (http://localhost:8000/test.js:28:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at n (http://localhost:8000/test.js:33:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at p (http://localhost:8000/test.js:38:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    Nitro



                                                    func.name: 
                                                    Trace:
                                                    a@http://localhost:8000/test.js:4:22
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: b
                                                    Trace:
                                                    b@http://localhost:8000/test.js:7:26
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: d
                                                    Trace:
                                                    d@http://localhost:8000/test.js:10:26
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name:
                                                    Trace:
                                                    a@http://localhost:8000/test.js:4:22
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: b
                                                    Trace:
                                                    b@http://localhost:8000/test.js:7:26
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: d
                                                    Trace:
                                                    d@http://localhost:8000/test.js:10:26
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name:
                                                    Trace:
                                                    i@http://localhost:8000/test.js:17:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: j
                                                    Trace:
                                                    j@http://localhost:8000/test.js:20:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: l
                                                    Trace:
                                                    l@http://localhost:8000/test.js:23:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name:
                                                    Trace:
                                                    http://localhost:8000/test.js:28:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: n
                                                    Trace:
                                                    n@http://localhost:8000/test.js:33:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: p
                                                    Trace:
                                                    p@http://localhost:8000/test.js:38:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33





                                                    share|improve this answer














                                                    In light of the "named functions show up in stack traces" argument, modern JavaScript engines are actually quite capable of representing anonymous functions.



                                                    As of this writing, V8, SpiderMonkey, Chakra and Nitro always refer to named functions by their names. They almost always refer to an anonymous function by its identifier if it has one.



                                                    SpiderMonkey can figure out the name of an anonymous function returned from another function. The rest can't.



                                                    If you really, really wanted your iterator and success callbacks to show up in the trace, you could name those too...



                                                    .forEach(function iterator() {});


                                                    But for the most part it's not worth stressing over.



                                                    Harness (Fiddle)



                                                    'use strict';

                                                    var a = function () {
                                                    throw new Error();
                                                    },
                                                    b = function b() {
                                                    throw new Error();
                                                    },
                                                    c = function d() {
                                                    throw new Error();
                                                    },
                                                    e = {
                                                    f: a,
                                                    g: b,
                                                    h: c,
                                                    i: function () {
                                                    throw new Error();
                                                    },
                                                    j: function j() {
                                                    throw new Error();
                                                    },
                                                    k: function l() {
                                                    throw new Error();
                                                    }
                                                    },
                                                    m = (function () {
                                                    return function () {
                                                    throw new Error();
                                                    };
                                                    }()),
                                                    n = (function () {
                                                    return function n() {
                                                    throw new Error();
                                                    };
                                                    }()),
                                                    o = (function () {
                                                    return function p() {
                                                    throw new Error();
                                                    };
                                                    }());

                                                    console.log([a, b, c].concat(Object.keys(e).reduce(function (values, key) {
                                                    return values.concat(e[key]);
                                                    }, )).concat([m, n, o]).reduce(function (logs, func) {

                                                    try {
                                                    func();
                                                    } catch (error) {
                                                    return logs.concat('func.name: ' + func.name + 'n' +
                                                    'Trace:n' +
                                                    error.stack);
                                                    // Need to manually log the error object in Nitro.
                                                    }

                                                    }, ).join('nn'));


                                                    V8



                                                    func.name: 
                                                    Trace:
                                                    Error
                                                    at a (http://localhost:8000/test.js:4:11)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: b
                                                    Trace:
                                                    Error
                                                    at b (http://localhost:8000/test.js:7:15)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: d
                                                    Trace:
                                                    Error
                                                    at d (http://localhost:8000/test.js:10:15)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name:
                                                    Trace:
                                                    Error
                                                    at a (http://localhost:8000/test.js:4:11)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: b
                                                    Trace:
                                                    Error
                                                    at b (http://localhost:8000/test.js:7:15)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: d
                                                    Trace:
                                                    Error
                                                    at d (http://localhost:8000/test.js:10:15)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name:
                                                    Trace:
                                                    Error
                                                    at e.i (http://localhost:8000/test.js:17:19)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: j
                                                    Trace:
                                                    Error
                                                    at j (http://localhost:8000/test.js:20:19)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: l
                                                    Trace:
                                                    Error
                                                    at l (http://localhost:8000/test.js:23:19)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name:
                                                    Trace:
                                                    Error
                                                    at http://localhost:8000/test.js:28:19
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: n
                                                    Trace:
                                                    Error
                                                    at n (http://localhost:8000/test.js:33:19)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27

                                                    func.name: p
                                                    Trace:
                                                    Error
                                                    at p (http://localhost:8000/test.js:38:19)
                                                    at http://localhost:8000/test.js:47:9
                                                    at Array.reduce (native)
                                                    at http://localhost:8000/test.js:44:27 test.js:42


                                                    SpiderMonkey



                                                    func.name: 
                                                    Trace:
                                                    a@http://localhost:8000/test.js:4:5
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: b
                                                    Trace:
                                                    b@http://localhost:8000/test.js:7:9
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: d
                                                    Trace:
                                                    d@http://localhost:8000/test.js:10:9
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name:
                                                    Trace:
                                                    a@http://localhost:8000/test.js:4:5
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: b
                                                    Trace:
                                                    b@http://localhost:8000/test.js:7:9
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: d
                                                    Trace:
                                                    d@http://localhost:8000/test.js:10:9
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name:
                                                    Trace:
                                                    e.i@http://localhost:8000/test.js:17:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: j
                                                    Trace:
                                                    j@http://localhost:8000/test.js:20:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: l
                                                    Trace:
                                                    l@http://localhost:8000/test.js:23:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name:
                                                    Trace:
                                                    m</<@http://localhost:8000/test.js:28:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: n
                                                    Trace:
                                                    n@http://localhost:8000/test.js:33:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    func.name: p
                                                    Trace:
                                                    p@http://localhost:8000/test.js:38:13
                                                    @http://localhost:8000/test.js:47:9
                                                    @http://localhost:8000/test.js:54:1


                                                    Chakra



                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at a (http://localhost:8000/test.js:4:5)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at b (http://localhost:8000/test.js:7:9)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at d (http://localhost:8000/test.js:10:9)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at a (http://localhost:8000/test.js:4:5)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at b (http://localhost:8000/test.js:7:9)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at d (http://localhost:8000/test.js:10:9)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at e.i (http://localhost:8000/test.js:17:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at j (http://localhost:8000/test.js:20:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at l (http://localhost:8000/test.js:23:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at Anonymous function (http://localhost:8000/test.js:28:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at n (http://localhost:8000/test.js:33:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    func.name: undefined
                                                    Trace:
                                                    Error
                                                    at p (http://localhost:8000/test.js:38:13)
                                                    at Anonymous function (http://localhost:8000/test.js:47:9)
                                                    at Global code (http://localhost:8000/test.js:42:1)


                                                    Nitro



                                                    func.name: 
                                                    Trace:
                                                    a@http://localhost:8000/test.js:4:22
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: b
                                                    Trace:
                                                    b@http://localhost:8000/test.js:7:26
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: d
                                                    Trace:
                                                    d@http://localhost:8000/test.js:10:26
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name:
                                                    Trace:
                                                    a@http://localhost:8000/test.js:4:22
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: b
                                                    Trace:
                                                    b@http://localhost:8000/test.js:7:26
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: d
                                                    Trace:
                                                    d@http://localhost:8000/test.js:10:26
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name:
                                                    Trace:
                                                    i@http://localhost:8000/test.js:17:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: j
                                                    Trace:
                                                    j@http://localhost:8000/test.js:20:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: l
                                                    Trace:
                                                    l@http://localhost:8000/test.js:23:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name:
                                                    Trace:
                                                    http://localhost:8000/test.js:28:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: n
                                                    Trace:
                                                    n@http://localhost:8000/test.js:33:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33

                                                    func.name: p
                                                    Trace:
                                                    p@http://localhost:8000/test.js:38:30
                                                    http://localhost:8000/test.js:47:13
                                                    reduce@[native code]
                                                    global code@http://localhost:8000/test.js:44:33






                                                    share|improve this answer














                                                    share|improve this answer



                                                    share|improve this answer








                                                    edited Jan 13 '15 at 3:24

























                                                    answered Oct 12 '14 at 0:58









                                                    Jackson

                                                    5,41123452




                                                    5,41123452























                                                        10














                                                        In JavaScript there are two ways to create functions:





                                                        1. Function declaration:



                                                          function fn(){
                                                          console.log("Hello");
                                                          }
                                                          fn();


                                                          This is very basic, self-explanatory, used in many languages and standard across C family of languages. We declared a function defined it and executed it by calling it.



                                                          What you should be knowing is that functions are actually objects in JavaScript; internally we have created an object for above function and given it a name called fn or the reference to the object is stored in fn. Functions are objects in JavaScript; an instance of function is actually an object instance.




                                                        2. Function expression:



                                                          var fn=function(){
                                                          console.log("Hello");
                                                          }
                                                          fn();


                                                          JavaScript has first-class functions, that is, create a function and assign it to a variable just like you create a string or number and assign it to a variable. Here, the fn variable is assigned to a function. The reason for this concept is functions are objects in JavaScript; fn is pointing to the object instance of the above function. We have initialized a function and assigned it to a variable. It's not executing the function and assigning the result.




                                                        Reference: JavaScript function declaration syntax: var fn = function() {} vs function fn() {}






                                                        share|improve this answer



















                                                        • 1




                                                          what about the third option, var fn = function fn() {...}?
                                                          – chharvey
                                                          Aug 20 '16 at 0:40










                                                        • Hi Chharvey, not sure about ur question, I guess u r talking about function expression which I have already mentioned. However, if still there is some confusion just be more elaborative.
                                                          – Anoop Rai
                                                          Aug 23 '16 at 10:00










                                                        • yes I was asking about a named function expression. it's similar to your option #2 except that the function has an identifier. usually this identifier is the same as the variable it's being assigned to, but that's not always the case.
                                                          – chharvey
                                                          Aug 23 '16 at 10:39






                                                        • 1




                                                          Yes Named function expression is similar to my option #2. Well having an identifier is not mandatory as it's not used. Whenever you will be executing the function expression you will use the variable holding the function object. Identifier serves no purpose.
                                                          – Anoop Rai
                                                          Aug 23 '16 at 11:42


















                                                        10














                                                        In JavaScript there are two ways to create functions:





                                                        1. Function declaration:



                                                          function fn(){
                                                          console.log("Hello");
                                                          }
                                                          fn();


                                                          This is very basic, self-explanatory, used in many languages and standard across C family of languages. We declared a function defined it and executed it by calling it.



                                                          What you should be knowing is that functions are actually objects in JavaScript; internally we have created an object for above function and given it a name called fn or the reference to the object is stored in fn. Functions are objects in JavaScript; an instance of function is actually an object instance.




                                                        2. Function expression:



                                                          var fn=function(){
                                                          console.log("Hello");
                                                          }
                                                          fn();


                                                          JavaScript has first-class functions, that is, create a function and assign it to a variable just like you create a string or number and assign it to a variable. Here, the fn variable is assigned to a function. The reason for this concept is functions are objects in JavaScript; fn is pointing to the object instance of the above function. We have initialized a function and assigned it to a variable. It's not executing the function and assigning the result.




                                                        Reference: JavaScript function declaration syntax: var fn = function() {} vs function fn() {}






                                                        share|improve this answer



















                                                        • 1




                                                          what about the third option, var fn = function fn() {...}?
                                                          – chharvey
                                                          Aug 20 '16 at 0:40










                                                        • Hi Chharvey, not sure about ur question, I guess u r talking about function expression which I have already mentioned. However, if still there is some confusion just be more elaborative.
                                                          – Anoop Rai
                                                          Aug 23 '16 at 10:00










                                                        • yes I was asking about a named function expression. it's similar to your option #2 except that the function has an identifier. usually this identifier is the same as the variable it's being assigned to, but that's not always the case.
                                                          – chharvey
                                                          Aug 23 '16 at 10:39






                                                        • 1




                                                          Yes Named function expression is similar to my option #2. Well having an identifier is not mandatory as it's not used. Whenever you will be executing the function expression you will use the variable holding the function object. Identifier serves no purpose.
                                                          – Anoop Rai
                                                          Aug 23 '16 at 11:42
















                                                        10












                                                        10








                                                        10






                                                        In JavaScript there are two ways to create functions:





                                                        1. Function declaration:



                                                          function fn(){
                                                          console.log("Hello");
                                                          }
                                                          fn();


                                                          This is very basic, self-explanatory, used in many languages and standard across C family of languages. We declared a function defined it and executed it by calling it.



                                                          What you should be knowing is that functions are actually objects in JavaScript; internally we have created an object for above function and given it a name called fn or the reference to the object is stored in fn. Functions are objects in JavaScript; an instance of function is actually an object instance.




                                                        2. Function expression:



                                                          var fn=function(){
                                                          console.log("Hello");
                                                          }
                                                          fn();


                                                          JavaScript has first-class functions, that is, create a function and assign it to a variable just like you create a string or number and assign it to a variable. Here, the fn variable is assigned to a function. The reason for this concept is functions are objects in JavaScript; fn is pointing to the object instance of the above function. We have initialized a function and assigned it to a variable. It's not executing the function and assigning the result.




                                                        Reference: JavaScript function declaration syntax: var fn = function() {} vs function fn() {}






                                                        share|improve this answer














                                                        In JavaScript there are two ways to create functions:





                                                        1. Function declaration:



                                                          function fn(){
                                                          console.log("Hello");
                                                          }
                                                          fn();


                                                          This is very basic, self-explanatory, used in many languages and standard across C family of languages. We declared a function defined it and executed it by calling it.



                                                          What you should be knowing is that functions are actually objects in JavaScript; internally we have created an object for above function and given it a name called fn or the reference to the object is stored in fn. Functions are objects in JavaScript; an instance of function is actually an object instance.




                                                        2. Function expression:



                                                          var fn=function(){
                                                          console.log("Hello");
                                                          }
                                                          fn();


                                                          JavaScript has first-class functions, that is, create a function and assign it to a variable just like you create a string or number and assign it to a variable. Here, the fn variable is assigned to a function. The reason for this concept is functions are objects in JavaScript; fn is pointing to the object instance of the above function. We have initialized a function and assigned it to a variable. It's not executing the function and assigning the result.




                                                        Reference: JavaScript function declaration syntax: var fn = function() {} vs function fn() {}







                                                        share|improve this answer














                                                        share|improve this answer



                                                        share|improve this answer








                                                        edited Apr 9 '17 at 7:13









                                                        Peter Mortensen

                                                        13.5k1983111




                                                        13.5k1983111










                                                        answered Aug 14 '16 at 9:13









                                                        Anoop Rai

                                                        21933




                                                        21933








                                                        • 1




                                                          what about the third option, var fn = function fn() {...}?
                                                          – chharvey
                                                          Aug 20 '16 at 0:40










                                                        • Hi Chharvey, not sure about ur question, I guess u r talking about function expression which I have already mentioned. However, if still there is some confusion just be more elaborative.
                                                          – Anoop Rai
                                                          Aug 23 '16 at 10:00










                                                        • yes I was asking about a named function expression. it's similar to your option #2 except that the function has an identifier. usually this identifier is the same as the variable it's being assigned to, but that's not always the case.
                                                          – chharvey
                                                          Aug 23 '16 at 10:39






                                                        • 1




                                                          Yes Named function expression is similar to my option #2. Well having an identifier is not mandatory as it's not used. Whenever you will be executing the function expression you will use the variable holding the function object. Identifier serves no purpose.
                                                          – Anoop Rai
                                                          Aug 23 '16 at 11:42
















                                                        • 1




                                                          what about the third option, var fn = function fn() {...}?
                                                          – chharvey
                                                          Aug 20 '16 at 0:40










                                                        • Hi Chharvey, not sure about ur question, I guess u r talking about function expression which I have already mentioned. However, if still there is some confusion just be more elaborative.
                                                          – Anoop Rai
                                                          Aug 23 '16 at 10:00










                                                        • yes I was asking about a named function expression. it's similar to your option #2 except that the function has an identifier. usually this identifier is the same as the variable it's being assigned to, but that's not always the case.
                                                          – chharvey
                                                          Aug 23 '16 at 10:39






                                                        • 1




                                                          Yes Named function expression is similar to my option #2. Well having an identifier is not mandatory as it's not used. Whenever you will be executing the function expression you will use the variable holding the function object. Identifier serves no purpose.
                                                          – Anoop Rai
                                                          Aug 23 '16 at 11:42










                                                        1




                                                        1




                                                        what about the third option, var fn = function fn() {...}?
                                                        – chharvey
                                                        Aug 20 '16 at 0:40




                                                        what about the third option, var fn = function fn() {...}?
                                                        – chharvey
                                                        Aug 20 '16 at 0:40












                                                        Hi Chharvey, not sure about ur question, I guess u r talking about function expression which I have already mentioned. However, if still there is some confusion just be more elaborative.
                                                        – Anoop Rai
                                                        Aug 23 '16 at 10:00




                                                        Hi Chharvey, not sure about ur question, I guess u r talking about function expression which I have already mentioned. However, if still there is some confusion just be more elaborative.
                                                        – Anoop Rai
                                                        Aug 23 '16 at 10:00












                                                        yes I was asking about a named function expression. it's similar to your option #2 except that the function has an identifier. usually this identifier is the same as the variable it's being assigned to, but that's not always the case.
                                                        – chharvey
                                                        Aug 23 '16 at 10:39




                                                        yes I was asking about a named function expression. it's similar to your option #2 except that the function has an identifier. usually this identifier is the same as the variable it's being assigned to, but that's not always the case.
                                                        – chharvey
                                                        Aug 23 '16 at 10:39




                                                        1




                                                        1




                                                        Yes Named function expression is similar to my option #2. Well having an identifier is not mandatory as it's not used. Whenever you will be executing the function expression you will use the variable holding the function object. Identifier serves no purpose.
                                                        – Anoop Rai
                                                        Aug 23 '16 at 11:42






                                                        Yes Named function expression is similar to my option #2. Well having an identifier is not mandatory as it's not used. Whenever you will be executing the function expression you will use the variable holding the function object. Identifier serves no purpose.
                                                        – Anoop Rai
                                                        Aug 23 '16 at 11:42













                                                        10














                                                        There are four noteworthy comparisons between the two different declarations of functions as listed below.




                                                        1. Availability (scope) of the function


                                                        The following works because function add() is scoped to the nearest block:






                                                        try {
                                                        console.log("Success: ", add(1, 1));
                                                        } catch(e) {
                                                        console.log("ERROR: " + e);
                                                        }

                                                        function add(a, b){
                                                        return a + b;
                                                        }





                                                        The following does not works (because the var add= superseeds the function add()).






                                                        try {
                                                        console.log("Success: ", add(1, 1));
                                                        } catch(e) {
                                                        console.log("ERROR: " + e);
                                                        }

                                                        var add=function add(a, b){
                                                        return a + b;
                                                        }





                                                        The following does not work because add is declared after it is used.






                                                        try {
                                                        console.log("Success: ", add(1, 1));
                                                        } catch(e) {
                                                        console.log("ERROR: " + e);
                                                        }

                                                        var add=function(a, b){
                                                        return a + b;
                                                        }







                                                        1. (function).name


                                                        The name of a function function thefuncname(){} is thefuncname when it is declared this way.






                                                        function foobar(a, b){}

                                                        console.log(foobar.name);








                                                        var a = function foobar(){};

                                                        console.log(a.name);





                                                        Otherwise, if a function is declared as function(){}, the function.name is the first variable used to store the function.






                                                        var a = function(){};
                                                        var b = (function(){ return function(){} });

                                                        console.log(a.name);
                                                        console.log(b.name);





                                                        If there are no variables set to the function, then the functions name is the empty string ("").






                                                        console.log((function(){}).name === "");





                                                        Lastly, while the variable the function is assigned to initially sets the name, successive variables set to the function do not change the name.






                                                        var a = function(){};
                                                        var b = a;
                                                        var c = b;

                                                        console.log(a.name);
                                                        console.log(b.name);
                                                        console.log(c.name);






                                                        1. Performance


                                                        In Google's V8 and Firefox's Spidermonkey there might be a few microsecond JIST compilation difference, but ultimately the result is the exact same. To prove this, let's examine the efficiency of JSPerf at microbenchmarks by comparing the speed of two blank code snippets. The JSPerf tests are found here. And, the jsben.ch testsare found here. As you can see, there is a noticable difference when there should be none. If you are really a performance freak like me, then it might be more worth your while trying to reduce the number of variables and functions in the scope and especially eliminating polymorphism (such as using the same variable to store two different types).




                                                        1. Variable Mutability


                                                        When you use the var keyword to declare a variable, you can then reassign a different value to the variable like so.






                                                        (function(){
                                                        "use strict";
                                                        var foobar = function(){}; // initial value
                                                        try {
                                                        foobar = "Hello World!"; // new value
                                                        console.log("[no error]");
                                                        } catch(error) {
                                                        console.log("ERROR: " + error.message);
                                                        }
                                                        console.log(foobar, window.foobar);
                                                        })();





                                                        However, when we use the const-statement, the variable reference becomes immutable. This means that we cannot assign a new value to the variable. Please note, however, that this does not make the contents of the variable immutable: if you do const arr = , then you can still do arr[10] = "example". Only doing something like arr = "new value" or arr = would throw an error as seen below.






                                                        (function(){
                                                        "use strict";
                                                        const foobar = function(){}; // initial value
                                                        try {
                                                        foobar = "Hello World!"; // new value
                                                        console.log("[no error]");
                                                        } catch(error) {
                                                        console.log("ERROR: " + error.message);
                                                        }
                                                        console.log(foobar, window.foobar);
                                                        })();





                                                        Interestingly, if we declare the variable as function funcName(){}, then the immutability of the variable is the same as declaring it with var.






                                                        (function(){
                                                        "use strict";
                                                        function foobar(){}; // initial value
                                                        try {
                                                        foobar = "Hello World!"; // new value
                                                        console.log("[no error]");
                                                        } catch(error) {
                                                        console.log("ERROR: " + error.message);
                                                        }
                                                        console.log(foobar, window.foobar);
                                                        })();





                                                        What Is The "Nearest Block"



                                                        The "nearest block" is the nearest "function," (including asynchronous functions, generator functions, and asynchronous generator functions). However, interestingly, a function functionName() {} behaves like a var functionName = function() {} when in a non-closure block to items outside said closure. Observe.




                                                        • Normal var add=function(){}





                                                        try {
                                                        // typeof will simply return "undefined" if the variable does not exist
                                                        if (typeof add !== "undefined") {
                                                        add(1, 1); // just to prove it
                                                        console.log("Not a block");
                                                        }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                        console.log('Behaves like var add=function(a,b){return a+b}');
                                                        }
                                                        } catch(e) {
                                                        console.log("Is a block");
                                                        }
                                                        var add=function(a, b){return a + b}






                                                        • Normal function add(){}





                                                        try {
                                                        // typeof will simply return "undefined" if the variable does not exist
                                                        if (typeof add !== "undefined") {
                                                        add(1, 1); // just to prove it
                                                        console.log("Not a block");
                                                        }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                        console.log('Behaves like var add=function(a,b){return a+b}')
                                                        }
                                                        } catch(e) {
                                                        console.log("Is a block");
                                                        }
                                                        function add(a, b){
                                                        return a + b;
                                                        }






                                                        • Function





                                                        try {
                                                        // typeof will simply return "undefined" if the variable does not exist
                                                        if (typeof add !== "undefined") {
                                                        add(1, 1); // just to prove it
                                                        console.log("Not a block");
                                                        }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                        console.log('Behaves like var add=function(a,b){return a+b}')
                                                        }
                                                        } catch(e) {
                                                        console.log("Is a block");
                                                        }
                                                        (function () {
                                                        function add(a, b){
                                                        return a + b;
                                                        }
                                                        })();






                                                        • Statement (such as if, else, for, while, try/catch/finally, switch, do/while, with)





                                                        try {
                                                        // typeof will simply return "undefined" if the variable does not exist
                                                        if (typeof add !== "undefined") {
                                                        add(1, 1); // just to prove it
                                                        console.log("Not a block");
                                                        }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                        console.log('Behaves like var add=function(a,b){return a+b}')
                                                        }
                                                        } catch(e) {
                                                        console.log("Is a block");
                                                        }
                                                        {
                                                        function add(a, b){
                                                        return a + b;
                                                        }
                                                        }






                                                        • Arrow Function with var add=function()





                                                        try {
                                                        // typeof will simply return "undefined" if the variable does not exist
                                                        if (typeof add !== "undefined") {
                                                        add(1, 1); // just to prove it
                                                        console.log("Not a block");
                                                        }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                        console.log('Behaves like var add=function(a,b){return a+b}')
                                                        }
                                                        } catch(e) {
                                                        console.log("Is a block");
                                                        }
                                                        (() => {
                                                        var add=function(a, b){
                                                        return a + b;
                                                        }
                                                        })();






                                                        • Arrow Function With function add()





                                                        try {
                                                        // typeof will simply return "undefined" if the variable does not exist
                                                        if (typeof add !== "undefined") {
                                                        add(1, 1); // just to prove it
                                                        console.log("Not a block");
                                                        }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                        console.log('Behaves like var add=function(a,b){return a+b}')
                                                        }
                                                        } catch(e) {
                                                        console.log("Is a block");
                                                        }
                                                        (() => {
                                                        function add(a, b){
                                                        return a + b;
                                                        }
                                                        })();








                                                        share|improve this answer




























                                                          10














                                                          There are four noteworthy comparisons between the two different declarations of functions as listed below.




                                                          1. Availability (scope) of the function


                                                          The following works because function add() is scoped to the nearest block:






                                                          try {
                                                          console.log("Success: ", add(1, 1));
                                                          } catch(e) {
                                                          console.log("ERROR: " + e);
                                                          }

                                                          function add(a, b){
                                                          return a + b;
                                                          }





                                                          The following does not works (because the var add= superseeds the function add()).






                                                          try {
                                                          console.log("Success: ", add(1, 1));
                                                          } catch(e) {
                                                          console.log("ERROR: " + e);
                                                          }

                                                          var add=function add(a, b){
                                                          return a + b;
                                                          }





                                                          The following does not work because add is declared after it is used.






                                                          try {
                                                          console.log("Success: ", add(1, 1));
                                                          } catch(e) {
                                                          console.log("ERROR: " + e);
                                                          }

                                                          var add=function(a, b){
                                                          return a + b;
                                                          }







                                                          1. (function).name


                                                          The name of a function function thefuncname(){} is thefuncname when it is declared this way.






                                                          function foobar(a, b){}

                                                          console.log(foobar.name);








                                                          var a = function foobar(){};

                                                          console.log(a.name);





                                                          Otherwise, if a function is declared as function(){}, the function.name is the first variable used to store the function.






                                                          var a = function(){};
                                                          var b = (function(){ return function(){} });

                                                          console.log(a.name);
                                                          console.log(b.name);





                                                          If there are no variables set to the function, then the functions name is the empty string ("").






                                                          console.log((function(){}).name === "");





                                                          Lastly, while the variable the function is assigned to initially sets the name, successive variables set to the function do not change the name.






                                                          var a = function(){};
                                                          var b = a;
                                                          var c = b;

                                                          console.log(a.name);
                                                          console.log(b.name);
                                                          console.log(c.name);






                                                          1. Performance


                                                          In Google's V8 and Firefox's Spidermonkey there might be a few microsecond JIST compilation difference, but ultimately the result is the exact same. To prove this, let's examine the efficiency of JSPerf at microbenchmarks by comparing the speed of two blank code snippets. The JSPerf tests are found here. And, the jsben.ch testsare found here. As you can see, there is a noticable difference when there should be none. If you are really a performance freak like me, then it might be more worth your while trying to reduce the number of variables and functions in the scope and especially eliminating polymorphism (such as using the same variable to store two different types).




                                                          1. Variable Mutability


                                                          When you use the var keyword to declare a variable, you can then reassign a different value to the variable like so.






                                                          (function(){
                                                          "use strict";
                                                          var foobar = function(){}; // initial value
                                                          try {
                                                          foobar = "Hello World!"; // new value
                                                          console.log("[no error]");
                                                          } catch(error) {
                                                          console.log("ERROR: " + error.message);
                                                          }
                                                          console.log(foobar, window.foobar);
                                                          })();





                                                          However, when we use the const-statement, the variable reference becomes immutable. This means that we cannot assign a new value to the variable. Please note, however, that this does not make the contents of the variable immutable: if you do const arr = , then you can still do arr[10] = "example". Only doing something like arr = "new value" or arr = would throw an error as seen below.






                                                          (function(){
                                                          "use strict";
                                                          const foobar = function(){}; // initial value
                                                          try {
                                                          foobar = "Hello World!"; // new value
                                                          console.log("[no error]");
                                                          } catch(error) {
                                                          console.log("ERROR: " + error.message);
                                                          }
                                                          console.log(foobar, window.foobar);
                                                          })();





                                                          Interestingly, if we declare the variable as function funcName(){}, then the immutability of the variable is the same as declaring it with var.






                                                          (function(){
                                                          "use strict";
                                                          function foobar(){}; // initial value
                                                          try {
                                                          foobar = "Hello World!"; // new value
                                                          console.log("[no error]");
                                                          } catch(error) {
                                                          console.log("ERROR: " + error.message);
                                                          }
                                                          console.log(foobar, window.foobar);
                                                          })();





                                                          What Is The "Nearest Block"



                                                          The "nearest block" is the nearest "function," (including asynchronous functions, generator functions, and asynchronous generator functions). However, interestingly, a function functionName() {} behaves like a var functionName = function() {} when in a non-closure block to items outside said closure. Observe.




                                                          • Normal var add=function(){}





                                                          try {
                                                          // typeof will simply return "undefined" if the variable does not exist
                                                          if (typeof add !== "undefined") {
                                                          add(1, 1); // just to prove it
                                                          console.log("Not a block");
                                                          }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                          console.log('Behaves like var add=function(a,b){return a+b}');
                                                          }
                                                          } catch(e) {
                                                          console.log("Is a block");
                                                          }
                                                          var add=function(a, b){return a + b}






                                                          • Normal function add(){}





                                                          try {
                                                          // typeof will simply return "undefined" if the variable does not exist
                                                          if (typeof add !== "undefined") {
                                                          add(1, 1); // just to prove it
                                                          console.log("Not a block");
                                                          }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                          console.log('Behaves like var add=function(a,b){return a+b}')
                                                          }
                                                          } catch(e) {
                                                          console.log("Is a block");
                                                          }
                                                          function add(a, b){
                                                          return a + b;
                                                          }






                                                          • Function





                                                          try {
                                                          // typeof will simply return "undefined" if the variable does not exist
                                                          if (typeof add !== "undefined") {
                                                          add(1, 1); // just to prove it
                                                          console.log("Not a block");
                                                          }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                          console.log('Behaves like var add=function(a,b){return a+b}')
                                                          }
                                                          } catch(e) {
                                                          console.log("Is a block");
                                                          }
                                                          (function () {
                                                          function add(a, b){
                                                          return a + b;
                                                          }
                                                          })();






                                                          • Statement (such as if, else, for, while, try/catch/finally, switch, do/while, with)





                                                          try {
                                                          // typeof will simply return "undefined" if the variable does not exist
                                                          if (typeof add !== "undefined") {
                                                          add(1, 1); // just to prove it
                                                          console.log("Not a block");
                                                          }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                          console.log('Behaves like var add=function(a,b){return a+b}')
                                                          }
                                                          } catch(e) {
                                                          console.log("Is a block");
                                                          }
                                                          {
                                                          function add(a, b){
                                                          return a + b;
                                                          }
                                                          }






                                                          • Arrow Function with var add=function()





                                                          try {
                                                          // typeof will simply return "undefined" if the variable does not exist
                                                          if (typeof add !== "undefined") {
                                                          add(1, 1); // just to prove it
                                                          console.log("Not a block");
                                                          }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                          console.log('Behaves like var add=function(a,b){return a+b}')
                                                          }
                                                          } catch(e) {
                                                          console.log("Is a block");
                                                          }
                                                          (() => {
                                                          var add=function(a, b){
                                                          return a + b;
                                                          }
                                                          })();






                                                          • Arrow Function With function add()





                                                          try {
                                                          // typeof will simply return "undefined" if the variable does not exist
                                                          if (typeof add !== "undefined") {
                                                          add(1, 1); // just to prove it
                                                          console.log("Not a block");
                                                          }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                          console.log('Behaves like var add=function(a,b){return a+b}')
                                                          }
                                                          } catch(e) {
                                                          console.log("Is a block");
                                                          }
                                                          (() => {
                                                          function add(a, b){
                                                          return a + b;
                                                          }
                                                          })();








                                                          share|improve this answer


























                                                            10












                                                            10








                                                            10






                                                            There are four noteworthy comparisons between the two different declarations of functions as listed below.




                                                            1. Availability (scope) of the function


                                                            The following works because function add() is scoped to the nearest block:






                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            function add(a, b){
                                                            return a + b;
                                                            }





                                                            The following does not works (because the var add= superseeds the function add()).






                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            var add=function add(a, b){
                                                            return a + b;
                                                            }





                                                            The following does not work because add is declared after it is used.






                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            var add=function(a, b){
                                                            return a + b;
                                                            }







                                                            1. (function).name


                                                            The name of a function function thefuncname(){} is thefuncname when it is declared this way.






                                                            function foobar(a, b){}

                                                            console.log(foobar.name);








                                                            var a = function foobar(){};

                                                            console.log(a.name);





                                                            Otherwise, if a function is declared as function(){}, the function.name is the first variable used to store the function.






                                                            var a = function(){};
                                                            var b = (function(){ return function(){} });

                                                            console.log(a.name);
                                                            console.log(b.name);





                                                            If there are no variables set to the function, then the functions name is the empty string ("").






                                                            console.log((function(){}).name === "");





                                                            Lastly, while the variable the function is assigned to initially sets the name, successive variables set to the function do not change the name.






                                                            var a = function(){};
                                                            var b = a;
                                                            var c = b;

                                                            console.log(a.name);
                                                            console.log(b.name);
                                                            console.log(c.name);






                                                            1. Performance


                                                            In Google's V8 and Firefox's Spidermonkey there might be a few microsecond JIST compilation difference, but ultimately the result is the exact same. To prove this, let's examine the efficiency of JSPerf at microbenchmarks by comparing the speed of two blank code snippets. The JSPerf tests are found here. And, the jsben.ch testsare found here. As you can see, there is a noticable difference when there should be none. If you are really a performance freak like me, then it might be more worth your while trying to reduce the number of variables and functions in the scope and especially eliminating polymorphism (such as using the same variable to store two different types).




                                                            1. Variable Mutability


                                                            When you use the var keyword to declare a variable, you can then reassign a different value to the variable like so.






                                                            (function(){
                                                            "use strict";
                                                            var foobar = function(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            However, when we use the const-statement, the variable reference becomes immutable. This means that we cannot assign a new value to the variable. Please note, however, that this does not make the contents of the variable immutable: if you do const arr = , then you can still do arr[10] = "example". Only doing something like arr = "new value" or arr = would throw an error as seen below.






                                                            (function(){
                                                            "use strict";
                                                            const foobar = function(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            Interestingly, if we declare the variable as function funcName(){}, then the immutability of the variable is the same as declaring it with var.






                                                            (function(){
                                                            "use strict";
                                                            function foobar(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            What Is The "Nearest Block"



                                                            The "nearest block" is the nearest "function," (including asynchronous functions, generator functions, and asynchronous generator functions). However, interestingly, a function functionName() {} behaves like a var functionName = function() {} when in a non-closure block to items outside said closure. Observe.




                                                            • Normal var add=function(){}





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}');
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            var add=function(a, b){return a + b}






                                                            • Normal function add(){}





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            function add(a, b){
                                                            return a + b;
                                                            }






                                                            • Function





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (function () {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            })();






                                                            • Statement (such as if, else, for, while, try/catch/finally, switch, do/while, with)





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            }






                                                            • Arrow Function with var add=function()





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (() => {
                                                            var add=function(a, b){
                                                            return a + b;
                                                            }
                                                            })();






                                                            • Arrow Function With function add()





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (() => {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            })();








                                                            share|improve this answer














                                                            There are four noteworthy comparisons between the two different declarations of functions as listed below.




                                                            1. Availability (scope) of the function


                                                            The following works because function add() is scoped to the nearest block:






                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            function add(a, b){
                                                            return a + b;
                                                            }





                                                            The following does not works (because the var add= superseeds the function add()).






                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            var add=function add(a, b){
                                                            return a + b;
                                                            }





                                                            The following does not work because add is declared after it is used.






                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            var add=function(a, b){
                                                            return a + b;
                                                            }







                                                            1. (function).name


                                                            The name of a function function thefuncname(){} is thefuncname when it is declared this way.






                                                            function foobar(a, b){}

                                                            console.log(foobar.name);








                                                            var a = function foobar(){};

                                                            console.log(a.name);





                                                            Otherwise, if a function is declared as function(){}, the function.name is the first variable used to store the function.






                                                            var a = function(){};
                                                            var b = (function(){ return function(){} });

                                                            console.log(a.name);
                                                            console.log(b.name);





                                                            If there are no variables set to the function, then the functions name is the empty string ("").






                                                            console.log((function(){}).name === "");





                                                            Lastly, while the variable the function is assigned to initially sets the name, successive variables set to the function do not change the name.






                                                            var a = function(){};
                                                            var b = a;
                                                            var c = b;

                                                            console.log(a.name);
                                                            console.log(b.name);
                                                            console.log(c.name);






                                                            1. Performance


                                                            In Google's V8 and Firefox's Spidermonkey there might be a few microsecond JIST compilation difference, but ultimately the result is the exact same. To prove this, let's examine the efficiency of JSPerf at microbenchmarks by comparing the speed of two blank code snippets. The JSPerf tests are found here. And, the jsben.ch testsare found here. As you can see, there is a noticable difference when there should be none. If you are really a performance freak like me, then it might be more worth your while trying to reduce the number of variables and functions in the scope and especially eliminating polymorphism (such as using the same variable to store two different types).




                                                            1. Variable Mutability


                                                            When you use the var keyword to declare a variable, you can then reassign a different value to the variable like so.






                                                            (function(){
                                                            "use strict";
                                                            var foobar = function(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            However, when we use the const-statement, the variable reference becomes immutable. This means that we cannot assign a new value to the variable. Please note, however, that this does not make the contents of the variable immutable: if you do const arr = , then you can still do arr[10] = "example". Only doing something like arr = "new value" or arr = would throw an error as seen below.






                                                            (function(){
                                                            "use strict";
                                                            const foobar = function(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            Interestingly, if we declare the variable as function funcName(){}, then the immutability of the variable is the same as declaring it with var.






                                                            (function(){
                                                            "use strict";
                                                            function foobar(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            What Is The "Nearest Block"



                                                            The "nearest block" is the nearest "function," (including asynchronous functions, generator functions, and asynchronous generator functions). However, interestingly, a function functionName() {} behaves like a var functionName = function() {} when in a non-closure block to items outside said closure. Observe.




                                                            • Normal var add=function(){}





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}');
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            var add=function(a, b){return a + b}






                                                            • Normal function add(){}





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            function add(a, b){
                                                            return a + b;
                                                            }






                                                            • Function





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (function () {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            })();






                                                            • Statement (such as if, else, for, while, try/catch/finally, switch, do/while, with)





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            }






                                                            • Arrow Function with var add=function()





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (() => {
                                                            var add=function(a, b){
                                                            return a + b;
                                                            }
                                                            })();






                                                            • Arrow Function With function add()





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (() => {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            })();








                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            function add(a, b){
                                                            return a + b;
                                                            }





                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            function add(a, b){
                                                            return a + b;
                                                            }





                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            var add=function add(a, b){
                                                            return a + b;
                                                            }





                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            var add=function add(a, b){
                                                            return a + b;
                                                            }





                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            var add=function(a, b){
                                                            return a + b;
                                                            }





                                                            try {
                                                            console.log("Success: ", add(1, 1));
                                                            } catch(e) {
                                                            console.log("ERROR: " + e);
                                                            }

                                                            var add=function(a, b){
                                                            return a + b;
                                                            }





                                                            function foobar(a, b){}

                                                            console.log(foobar.name);





                                                            function foobar(a, b){}

                                                            console.log(foobar.name);





                                                            var a = function foobar(){};

                                                            console.log(a.name);





                                                            var a = function foobar(){};

                                                            console.log(a.name);





                                                            var a = function(){};
                                                            var b = (function(){ return function(){} });

                                                            console.log(a.name);
                                                            console.log(b.name);





                                                            var a = function(){};
                                                            var b = (function(){ return function(){} });

                                                            console.log(a.name);
                                                            console.log(b.name);





                                                            console.log((function(){}).name === "");





                                                            console.log((function(){}).name === "");





                                                            var a = function(){};
                                                            var b = a;
                                                            var c = b;

                                                            console.log(a.name);
                                                            console.log(b.name);
                                                            console.log(c.name);





                                                            var a = function(){};
                                                            var b = a;
                                                            var c = b;

                                                            console.log(a.name);
                                                            console.log(b.name);
                                                            console.log(c.name);





                                                            (function(){
                                                            "use strict";
                                                            var foobar = function(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            (function(){
                                                            "use strict";
                                                            var foobar = function(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            (function(){
                                                            "use strict";
                                                            const foobar = function(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            (function(){
                                                            "use strict";
                                                            const foobar = function(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            (function(){
                                                            "use strict";
                                                            function foobar(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            (function(){
                                                            "use strict";
                                                            function foobar(){}; // initial value
                                                            try {
                                                            foobar = "Hello World!"; // new value
                                                            console.log("[no error]");
                                                            } catch(error) {
                                                            console.log("ERROR: " + error.message);
                                                            }
                                                            console.log(foobar, window.foobar);
                                                            })();





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}');
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            var add=function(a, b){return a + b}





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}');
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            var add=function(a, b){return a + b}





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            function add(a, b){
                                                            return a + b;
                                                            }





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            function add(a, b){
                                                            return a + b;
                                                            }





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (function () {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            })();





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (function () {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            })();





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            }





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            }





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (() => {
                                                            var add=function(a, b){
                                                            return a + b;
                                                            }
                                                            })();





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (() => {
                                                            var add=function(a, b){
                                                            return a + b;
                                                            }
                                                            })();





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (() => {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            })();





                                                            try {
                                                            // typeof will simply return "undefined" if the variable does not exist
                                                            if (typeof add !== "undefined") {
                                                            add(1, 1); // just to prove it
                                                            console.log("Not a block");
                                                            }else if(add===undefined){ // this throws an exception if add doesn't exist
                                                            console.log('Behaves like var add=function(a,b){return a+b}')
                                                            }
                                                            } catch(e) {
                                                            console.log("Is a block");
                                                            }
                                                            (() => {
                                                            function add(a, b){
                                                            return a + b;
                                                            }
                                                            })();






                                                            share|improve this answer














                                                            share|improve this answer



                                                            share|improve this answer








                                                            edited Nov 29 at 11:50

























                                                            answered Jan 15 at 1:55









                                                            Jack Giffin

                                                            1




                                                            1























                                                                8














                                                                Both are different ways of defining a function. The difference is how the browser interprets and loads them into an execution context.



                                                                The first case is of function expressions which loads only when the interpreter reaches that line of code. So if you do it like the following, you will get an error that the functionOne is not a function.



                                                                functionOne();
                                                                var functionOne = function() {
                                                                // Some code
                                                                };


                                                                The reason is that on the first line no value is assigned to functionOne, and hence it is undefined. We are trying to call it as a function, and hence we are getting an error.



                                                                On the second line we are assigning the reference of an anonymous function to functionOne.



                                                                The second case is of function declarations that loads before any code is executed. So if you do like the following you won't get any error as the declaration loads before code execution.



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





                                                                share|improve this answer




























                                                                  8














                                                                  Both are different ways of defining a function. The difference is how the browser interprets and loads them into an execution context.



                                                                  The first case is of function expressions which loads only when the interpreter reaches that line of code. So if you do it like the following, you will get an error that the functionOne is not a function.



                                                                  functionOne();
                                                                  var functionOne = function() {
                                                                  // Some code
                                                                  };


                                                                  The reason is that on the first line no value is assigned to functionOne, and hence it is undefined. We are trying to call it as a function, and hence we are getting an error.



                                                                  On the second line we are assigning the reference of an anonymous function to functionOne.



                                                                  The second case is of function declarations that loads before any code is executed. So if you do like the following you won't get any error as the declaration loads before code execution.



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





                                                                  share|improve this answer


























                                                                    8












                                                                    8








                                                                    8






                                                                    Both are different ways of defining a function. The difference is how the browser interprets and loads them into an execution context.



                                                                    The first case is of function expressions which loads only when the interpreter reaches that line of code. So if you do it like the following, you will get an error that the functionOne is not a function.



                                                                    functionOne();
                                                                    var functionOne = function() {
                                                                    // Some code
                                                                    };


                                                                    The reason is that on the first line no value is assigned to functionOne, and hence it is undefined. We are trying to call it as a function, and hence we are getting an error.



                                                                    On the second line we are assigning the reference of an anonymous function to functionOne.



                                                                    The second case is of function declarations that loads before any code is executed. So if you do like the following you won't get any error as the declaration loads before code execution.



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





                                                                    share|improve this answer














                                                                    Both are different ways of defining a function. The difference is how the browser interprets and loads them into an execution context.



                                                                    The first case is of function expressions which loads only when the interpreter reaches that line of code. So if you do it like the following, you will get an error that the functionOne is not a function.



                                                                    functionOne();
                                                                    var functionOne = function() {
                                                                    // Some code
                                                                    };


                                                                    The reason is that on the first line no value is assigned to functionOne, and hence it is undefined. We are trying to call it as a function, and hence we are getting an error.



                                                                    On the second line we are assigning the reference of an anonymous function to functionOne.



                                                                    The second case is of function declarations that loads before any code is executed. So if you do like the following you won't get any error as the declaration loads before code execution.



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






                                                                    share|improve this answer














                                                                    share|improve this answer



                                                                    share|improve this answer








                                                                    edited Dec 28 '15 at 20:42









                                                                    Peter Mortensen

                                                                    13.5k1983111




                                                                    13.5k1983111










                                                                    answered Dec 28 '15 at 20:18









                                                                    Nitin9791

                                                                    659713




                                                                    659713























                                                                        8














                                                                        About performance:



                                                                        New versions of V8 introduced several under-the-hood optimizations and so did SpiderMonkey.



                                                                        There is almost no difference now between expression and declaration.
                                                                        Function expression appears to be faster now.



                                                                        Chrome 62.0.3202
                                                                        Chrome test



                                                                        FireFox 55
                                                                        Firefox test



                                                                        Chrome Canary 63.0.3225
                                                                        Chrome Canary test







                                                                        Anonymous function expressions appear to have better performance
                                                                        against Named function expression.







                                                                        Firefox
                                                                        Firefox named_anonymousChrome Canary
                                                                        Chrome canary named_anonymousChrome
                                                                        Chrome named_anonymous






                                                                        share|improve this answer



















                                                                        • 1




                                                                          Yes, this difference is so insignificant that hopefully devs will concern themselves with which approach is more maintainable for their specific needs rather than which one might be faster (you'll get different jsperf results on each try depending on what the browser is doing -- the majority of javascript tasks needn't concern themselves with micro-optimizations to this degree).
                                                                          – squidbe
                                                                          Nov 26 '17 at 1:41












                                                                        • @squidbe There is no difference. Look here: jsperf.com/empty-tests-performance
                                                                          – Jack Giffin
                                                                          May 10 at 21:10
















                                                                        8














                                                                        About performance:



                                                                        New versions of V8 introduced several under-the-hood optimizations and so did SpiderMonkey.



                                                                        There is almost no difference now between expression and declaration.
                                                                        Function expression appears to be faster now.



                                                                        Chrome 62.0.3202
                                                                        Chrome test



                                                                        FireFox 55
                                                                        Firefox test



                                                                        Chrome Canary 63.0.3225
                                                                        Chrome Canary test







                                                                        Anonymous function expressions appear to have better performance
                                                                        against Named function expression.







                                                                        Firefox
                                                                        Firefox named_anonymousChrome Canary
                                                                        Chrome canary named_anonymousChrome
                                                                        Chrome named_anonymous






                                                                        share|improve this answer



















                                                                        • 1




                                                                          Yes, this difference is so insignificant that hopefully devs will concern themselves with which approach is more maintainable for their specific needs rather than which one might be faster (you'll get different jsperf results on each try depending on what the browser is doing -- the majority of javascript tasks needn't concern themselves with micro-optimizations to this degree).
                                                                          – squidbe
                                                                          Nov 26 '17 at 1:41












                                                                        • @squidbe There is no difference. Look here: jsperf.com/empty-tests-performance
                                                                          – Jack Giffin
                                                                          May 10 at 21:10














                                                                        8












                                                                        8








                                                                        8






                                                                        About performance:



                                                                        New versions of V8 introduced several under-the-hood optimizations and so did SpiderMonkey.



                                                                        There is almost no difference now between expression and declaration.
                                                                        Function expression appears to be faster now.



                                                                        Chrome 62.0.3202
                                                                        Chrome test



                                                                        FireFox 55
                                                                        Firefox test



                                                                        Chrome Canary 63.0.3225
                                                                        Chrome Canary test







                                                                        Anonymous function expressions appear to have better performance
                                                                        against Named function expression.







                                                                        Firefox
                                                                        Firefox named_anonymousChrome Canary
                                                                        Chrome canary named_anonymousChrome
                                                                        Chrome named_anonymous






                                                                        share|improve this answer














                                                                        About performance:



                                                                        New versions of V8 introduced several under-the-hood optimizations and so did SpiderMonkey.



                                                                        There is almost no difference now between expression and declaration.
                                                                        Function expression appears to be faster now.



                                                                        Chrome 62.0.3202
                                                                        Chrome test



                                                                        FireFox 55
                                                                        Firefox test



                                                                        Chrome Canary 63.0.3225
                                                                        Chrome Canary test







                                                                        Anonymous function expressions appear to have better performance
                                                                        against Named function expression.







                                                                        Firefox
                                                                        Firefox named_anonymousChrome Canary
                                                                        Chrome canary named_anonymousChrome
                                                                        Chrome named_anonymous







                                                                        share|improve this answer














                                                                        share|improve this answer



                                                                        share|improve this answer








                                                                        edited Sep 28 '17 at 5:13

























                                                                        answered Sep 28 '17 at 4:34









                                                                        Panos Kal.

                                                                        8,16984361




                                                                        8,16984361








                                                                        • 1




                                                                          Yes, this difference is so insignificant that hopefully devs will concern themselves with which approach is more maintainable for their specific needs rather than which one might be faster (you'll get different jsperf results on each try depending on what the browser is doing -- the majority of javascript tasks needn't concern themselves with micro-optimizations to this degree).
                                                                          – squidbe
                                                                          Nov 26 '17 at 1:41












                                                                        • @squidbe There is no difference. Look here: jsperf.com/empty-tests-performance
                                                                          – Jack Giffin
                                                                          May 10 at 21:10














                                                                        • 1




                                                                          Yes, this difference is so insignificant that hopefully devs will concern themselves with which approach is more maintainable for their specific needs rather than which one might be faster (you'll get different jsperf results on each try depending on what the browser is doing -- the majority of javascript tasks needn't concern themselves with micro-optimizations to this degree).
                                                                          – squidbe
                                                                          Nov 26 '17 at 1:41












                                                                        • @squidbe There is no difference. Look here: jsperf.com/empty-tests-performance
                                                                          – Jack Giffin
                                                                          May 10 at 21:10








                                                                        1




                                                                        1




                                                                        Yes, this difference is so insignificant that hopefully devs will concern themselves with which approach is more maintainable for their specific needs rather than which one might be faster (you'll get different jsperf results on each try depending on what the browser is doing -- the majority of javascript tasks needn't concern themselves with micro-optimizations to this degree).
                                                                        – squidbe
                                                                        Nov 26 '17 at 1:41






                                                                        Yes, this difference is so insignificant that hopefully devs will concern themselves with which approach is more maintainable for their specific needs rather than which one might be faster (you'll get different jsperf results on each try depending on what the browser is doing -- the majority of javascript tasks needn't concern themselves with micro-optimizations to this degree).
                                                                        – squidbe
                                                                        Nov 26 '17 at 1:41














                                                                        @squidbe There is no difference. Look here: jsperf.com/empty-tests-performance
                                                                        – Jack Giffin
                                                                        May 10 at 21:10




                                                                        @squidbe There is no difference. Look here: jsperf.com/empty-tests-performance
                                                                        – Jack Giffin
                                                                        May 10 at 21:10











                                                                        7














                                                                        They are pretty similar with some small differences, first one is a variable which assigned to an anonymous function (Function Declaration) and second one is the normal way to create a function in JavaScript(Anonymous function Declaration), both has usage, cons and pros:



                                                                        1. Function Expression



                                                                        var functionOne = function() {
                                                                        // Some code
                                                                        };



                                                                        A Function Expression defines a function as a part of a larger
                                                                        expression syntax (typically a variable assignment ). Functions
                                                                        defined via Functions Expressions can be named or anonymous. Function
                                                                        Expressions must not start with “function” (hence the parentheses
                                                                        around the self invoking example below).




                                                                        Assign a variable to a function, means no Hoisting, as we know functions in JavaScript can Hoist, means they can be called before they get declared, while variables need to be declared before getting access to them, so means in this case we can not access the function before where it's declared, also it could be a way that you write your functions, for the functions which return another function, this kind of declaration could make sense, also in ECMA6 & above you can assign this to an arrow function which can be used to call anonymous functions, also this way of declaring is a better way to create Constructor functions in JavaScript.



                                                                        2. Function Declaration



                                                                        function functionTwo() {
                                                                        // Some code
                                                                        }



                                                                        A Function Declaration defines a named function variable without
                                                                        requiring variable assignment. Function Declarations occur as
                                                                        standalone constructs and cannot be nested within non-function blocks.
                                                                        It’s helpful to think of them as siblings of Variable Declarations.
                                                                        Just as Variable Declarations must start with “var”, Function
                                                                        Declarations must begin with “function”.




                                                                        This is the normal way of calling a function in JavaScript, this function can be called before you even declare it as in JavaScript all functions get Hoisted, but if you have 'use strict' this won't Hoist as expected, it's a good way to call all normal functions which are not big in lines and neither are a constructor function.



                                                                        Also, if you need more info about how hoisting works in JavaScript, visit the link below:



                                                                        https://developer.mozilla.org/en-US/docs/Glossary/Hoisting






                                                                        share|improve this answer



















                                                                        • 1




                                                                          ...also this way of declaring is a better way to create Constructor functions in JavaScript , may you please elaborate, I'm curious!
                                                                          – Karl Morrison
                                                                          Jun 13 '17 at 12:44












                                                                        • One reason is because all built-in Constructor functions in JavaScript created like this function Number() { [native code] } and you shouldn't be confused with built-in ones, also referencing later on in this case is safer and you end up neater code but not using hoisting...
                                                                          – Alireza
                                                                          Jun 13 '17 at 12:56


















                                                                        7














                                                                        They are pretty similar with some small differences, first one is a variable which assigned to an anonymous function (Function Declaration) and second one is the normal way to create a function in JavaScript(Anonymous function Declaration), both has usage, cons and pros:



                                                                        1. Function Expression



                                                                        var functionOne = function() {
                                                                        // Some code
                                                                        };



                                                                        A Function Expression defines a function as a part of a larger
                                                                        expression syntax (typically a variable assignment ). Functions
                                                                        defined via Functions Expressions can be named or anonymous. Function
                                                                        Expressions must not start with “function” (hence the parentheses
                                                                        around the self invoking example below).




                                                                        Assign a variable to a function, means no Hoisting, as we know functions in JavaScript can Hoist, means they can be called before they get declared, while variables need to be declared before getting access to them, so means in this case we can not access the function before where it's declared, also it could be a way that you write your functions, for the functions which return another function, this kind of declaration could make sense, also in ECMA6 & above you can assign this to an arrow function which can be used to call anonymous functions, also this way of declaring is a better way to create Constructor functions in JavaScript.



                                                                        2. Function Declaration



                                                                        function functionTwo() {
                                                                        // Some code
                                                                        }



                                                                        A Function Declaration defines a named function variable without
                                                                        requiring variable assignment. Function Declarations occur as
                                                                        standalone constructs and cannot be nested within non-function blocks.
                                                                        It’s helpful to think of them as siblings of Variable Declarations.
                                                                        Just as Variable Declarations must start with “var”, Function
                                                                        Declarations must begin with “function”.




                                                                        This is the normal way of calling a function in JavaScript, this function can be called before you even declare it as in JavaScript all functions get Hoisted, but if you have 'use strict' this won't Hoist as expected, it's a good way to call all normal functions which are not big in lines and neither are a constructor function.



                                                                        Also, if you need more info about how hoisting works in JavaScript, visit the link below:



                                                                        https://developer.mozilla.org/en-US/docs/Glossary/Hoisting






                                                                        share|improve this answer



















                                                                        • 1




                                                                          ...also this way of declaring is a better way to create Constructor functions in JavaScript , may you please elaborate, I'm curious!
                                                                          – Karl Morrison
                                                                          Jun 13 '17 at 12:44












                                                                        • One reason is because all built-in Constructor functions in JavaScript created like this function Number() { [native code] } and you shouldn't be confused with built-in ones, also referencing later on in this case is safer and you end up neater code but not using hoisting...
                                                                          – Alireza
                                                                          Jun 13 '17 at 12:56
















                                                                        7












                                                                        7








                                                                        7






                                                                        They are pretty similar with some small differences, first one is a variable which assigned to an anonymous function (Function Declaration) and second one is the normal way to create a function in JavaScript(Anonymous function Declaration), both has usage, cons and pros:



                                                                        1. Function Expression



                                                                        var functionOne = function() {
                                                                        // Some code
                                                                        };



                                                                        A Function Expression defines a function as a part of a larger
                                                                        expression syntax (typically a variable assignment ). Functions
                                                                        defined via Functions Expressions can be named or anonymous. Function
                                                                        Expressions must not start with “function” (hence the parentheses
                                                                        around the self invoking example below).




                                                                        Assign a variable to a function, means no Hoisting, as we know functions in JavaScript can Hoist, means they can be called before they get declared, while variables need to be declared before getting access to them, so means in this case we can not access the function before where it's declared, also it could be a way that you write your functions, for the functions which return another function, this kind of declaration could make sense, also in ECMA6 & above you can assign this to an arrow function which can be used to call anonymous functions, also this way of declaring is a better way to create Constructor functions in JavaScript.



                                                                        2. Function Declaration



                                                                        function functionTwo() {
                                                                        // Some code
                                                                        }



                                                                        A Function Declaration defines a named function variable without
                                                                        requiring variable assignment. Function Declarations occur as
                                                                        standalone constructs and cannot be nested within non-function blocks.
                                                                        It’s helpful to think of them as siblings of Variable Declarations.
                                                                        Just as Variable Declarations must start with “var”, Function
                                                                        Declarations must begin with “function”.




                                                                        This is the normal way of calling a function in JavaScript, this function can be called before you even declare it as in JavaScript all functions get Hoisted, but if you have 'use strict' this won't Hoist as expected, it's a good way to call all normal functions which are not big in lines and neither are a constructor function.



                                                                        Also, if you need more info about how hoisting works in JavaScript, visit the link below:



                                                                        https://developer.mozilla.org/en-US/docs/Glossary/Hoisting






                                                                        share|improve this answer














                                                                        They are pretty similar with some small differences, first one is a variable which assigned to an anonymous function (Function Declaration) and second one is the normal way to create a function in JavaScript(Anonymous function Declaration), both has usage, cons and pros:



                                                                        1. Function Expression



                                                                        var functionOne = function() {
                                                                        // Some code
                                                                        };



                                                                        A Function Expression defines a function as a part of a larger
                                                                        expression syntax (typically a variable assignment ). Functions
                                                                        defined via Functions Expressions can be named or anonymous. Function
                                                                        Expressions must not start with “function” (hence the parentheses
                                                                        around the self invoking example below).




                                                                        Assign a variable to a function, means no Hoisting, as we know functions in JavaScript can Hoist, means they can be called before they get declared, while variables need to be declared before getting access to them, so means in this case we can not access the function before where it's declared, also it could be a way that you write your functions, for the functions which return another function, this kind of declaration could make sense, also in ECMA6 & above you can assign this to an arrow function which can be used to call anonymous functions, also this way of declaring is a better way to create Constructor functions in JavaScript.



                                                                        2. Function Declaration



                                                                        function functionTwo() {
                                                                        // Some code
                                                                        }



                                                                        A Function Declaration defines a named function variable without
                                                                        requiring variable assignment. Function Declarations occur as
                                                                        standalone constructs and cannot be nested within non-function blocks.
                                                                        It’s helpful to think of them as siblings of Variable Declarations.
                                                                        Just as Variable Declarations must start with “var”, Function
                                                                        Declarations must begin with “function”.




                                                                        This is the normal way of calling a function in JavaScript, this function can be called before you even declare it as in JavaScript all functions get Hoisted, but if you have 'use strict' this won't Hoist as expected, it's a good way to call all normal functions which are not big in lines and neither are a constructor function.



                                                                        Also, if you need more info about how hoisting works in JavaScript, visit the link below:



                                                                        https://developer.mozilla.org/en-US/docs/Glossary/Hoisting







                                                                        share|improve this answer














                                                                        share|improve this answer



                                                                        share|improve this answer








                                                                        edited Jul 30 '17 at 4:30

























                                                                        answered May 9 '17 at 13:56









                                                                        Alireza

                                                                        45k12165119




                                                                        45k12165119








                                                                        • 1




                                                                          ...also this way of declaring is a better way to create Constructor functions in JavaScript , may you please elaborate, I'm curious!
                                                                          – Karl Morrison
                                                                          Jun 13 '17 at 12:44












                                                                        • One reason is because all built-in Constructor functions in JavaScript created like this function Number() { [native code] } and you shouldn't be confused with built-in ones, also referencing later on in this case is safer and you end up neater code but not using hoisting...
                                                                          – Alireza
                                                                          Jun 13 '17 at 12:56
















                                                                        • 1




                                                                          ...also this way of declaring is a better way to create Constructor functions in JavaScript , may you please elaborate, I'm curious!
                                                                          – Karl Morrison
                                                                          Jun 13 '17 at 12:44












                                                                        • One reason is because all built-in Constructor functions in JavaScript created like this function Number() { [native code] } and you shouldn't be confused with built-in ones, also referencing later on in this case is safer and you end up neater code but not using hoisting...
                                                                          – Alireza
                                                                          Jun 13 '17 at 12:56










                                                                        1




                                                                        1




                                                                        ...also this way of declaring is a better way to create Constructor functions in JavaScript , may you please elaborate, I'm curious!
                                                                        – Karl Morrison
                                                                        Jun 13 '17 at 12:44






                                                                        ...also this way of declaring is a better way to create Constructor functions in JavaScript , may you please elaborate, I'm curious!
                                                                        – Karl Morrison
                                                                        Jun 13 '17 at 12:44














                                                                        One reason is because all built-in Constructor functions in JavaScript created like this function Number() { [native code] } and you shouldn't be confused with built-in ones, also referencing later on in this case is safer and you end up neater code but not using hoisting...
                                                                        – Alireza
                                                                        Jun 13 '17 at 12:56






                                                                        One reason is because all built-in Constructor functions in JavaScript created like this function Number() { [native code] } and you shouldn't be confused with built-in ones, also referencing later on in this case is safer and you end up neater code but not using hoisting...
                                                                        – Alireza
                                                                        Jun 13 '17 at 12:56













                                                                        5














                                                                        This is just two possible ways of declaring functions, and in the second way, you can use the function before declaration.






                                                                        share|improve this answer























                                                                        • Please elaborate and provide working code snippets
                                                                          – Jack Giffin
                                                                          May 10 at 21:06
















                                                                        5














                                                                        This is just two possible ways of declaring functions, and in the second way, you can use the function before declaration.






                                                                        share|improve this answer























                                                                        • Please elaborate and provide working code snippets
                                                                          – Jack Giffin
                                                                          May 10 at 21:06














                                                                        5












                                                                        5








                                                                        5






                                                                        This is just two possible ways of declaring functions, and in the second way, you can use the function before declaration.






                                                                        share|improve this answer














                                                                        This is just two possible ways of declaring functions, and in the second way, you can use the function before declaration.







                                                                        share|improve this answer














                                                                        share|improve this answer



                                                                        share|improve this answer








                                                                        edited Dec 28 '15 at 20:32









                                                                        Peter Mortensen

                                                                        13.5k1983111




                                                                        13.5k1983111










                                                                        answered Jun 24 '15 at 10:08









                                                                        Tao

                                                                        38146




                                                                        38146












                                                                        • Please elaborate and provide working code snippets
                                                                          – Jack Giffin
                                                                          May 10 at 21:06


















                                                                        • Please elaborate and provide working code snippets
                                                                          – Jack Giffin
                                                                          May 10 at 21:06
















                                                                        Please elaborate and provide working code snippets
                                                                        – Jack Giffin
                                                                        May 10 at 21:06




                                                                        Please elaborate and provide working code snippets
                                                                        – Jack Giffin
                                                                        May 10 at 21:06











                                                                        4














                                                                        new Function() can be used to pass the function's body in a string. And hence this can be used to create dynamic functions. Also passing the script without executing the script.



                                                                        var func = new Function("x", "y", "return x*y;");
                                                                        function secondFunction(){
                                                                        var result;
                                                                        result = func(10,20);
                                                                        console.log ( result );
                                                                        }

                                                                        secondFunction()





                                                                        share|improve this answer





















                                                                        • While this is good and true, how exactly does this alone relate to the quesiton being asked?
                                                                          – Jack Giffin
                                                                          May 10 at 21:06
















                                                                        4














                                                                        new Function() can be used to pass the function's body in a string. And hence this can be used to create dynamic functions. Also passing the script without executing the script.



                                                                        var func = new Function("x", "y", "return x*y;");
                                                                        function secondFunction(){
                                                                        var result;
                                                                        result = func(10,20);
                                                                        console.log ( result );
                                                                        }

                                                                        secondFunction()





                                                                        share|improve this answer





















                                                                        • While this is good and true, how exactly does this alone relate to the quesiton being asked?
                                                                          – Jack Giffin
                                                                          May 10 at 21:06














                                                                        4












                                                                        4








                                                                        4






                                                                        new Function() can be used to pass the function's body in a string. And hence this can be used to create dynamic functions. Also passing the script without executing the script.



                                                                        var func = new Function("x", "y", "return x*y;");
                                                                        function secondFunction(){
                                                                        var result;
                                                                        result = func(10,20);
                                                                        console.log ( result );
                                                                        }

                                                                        secondFunction()





                                                                        share|improve this answer












                                                                        new Function() can be used to pass the function's body in a string. And hence this can be used to create dynamic functions. Also passing the script without executing the script.



                                                                        var func = new Function("x", "y", "return x*y;");
                                                                        function secondFunction(){
                                                                        var result;
                                                                        result = func(10,20);
                                                                        console.log ( result );
                                                                        }

                                                                        secondFunction()






                                                                        share|improve this answer












                                                                        share|improve this answer



                                                                        share|improve this answer










                                                                        answered May 10 '16 at 7:05









                                                                        SuperNova

                                                                        5,32722520




                                                                        5,32722520












                                                                        • While this is good and true, how exactly does this alone relate to the quesiton being asked?
                                                                          – Jack Giffin
                                                                          May 10 at 21:06


















                                                                        • While this is good and true, how exactly does this alone relate to the quesiton being asked?
                                                                          – Jack Giffin
                                                                          May 10 at 21:06
















                                                                        While this is good and true, how exactly does this alone relate to the quesiton being asked?
                                                                        – Jack Giffin
                                                                        May 10 at 21:06




                                                                        While this is good and true, how exactly does this alone relate to the quesiton being asked?
                                                                        – Jack Giffin
                                                                        May 10 at 21:06










                                                                        1 2
                                                                        next




                                                                        protected by NullPoiиteя Jun 10 '13 at 5:05



                                                                        Thank you for your interest in this question.
                                                                        Because it has attracted low-quality or spam answers that had to be removed, posting an answer now requires 10 reputation on this site (the association bonus does not count).



                                                                        Would you like to answer one of these unanswered questions instead?



                                                                        Popular posts from this blog

                                                                        Bressuire

                                                                        Vorschmack

                                                                        Quarantine