Introduction
Functions are a fundamental part of JavaScript, enabling you to encapsulate code for reuse and manage the flow of your application. This chapter will guide you through the basics of functions, including function declarations, expressions, arrow functions, and the concept of scope in JavaScript.
Understanding Functions
What is a Function?
A function is a reusable block of code designed to perform a particular task. It can take inputs, process them, and return an output. Functions help in breaking down a program into smaller, manageable pieces, making the code more organized and efficient.
Function Declaration
A function declaration defines a named function using the function keyword, followed by the function name, parameters, and a block of code.
Example: Function Declaration
function greet(name) {
return `Hello, ${name}!`;
}
console.log(greet("Alice")); // Output: Hello, Alice!
Function Expression
A function expression defines a function within an expression, typically assigned to a variable.
Example: Function Expression
const add = function (a, b) {
return a + b;
};
console.log(add(5, 3)); // Output: 8
Arrow Functions
Arrow functions provide a more concise syntax for writing functions and are always anonymous. They are particularly useful for simple operations and callbacks.
Example: Arrow Function
const multiply = (a, b) => a * b;
console.log(multiply(4, 2)); // Output: 8
JavaScript Scope
Scope determines the visibility and accessibility of variables within different parts of your code. JavaScript has two main types of scope: global scope and local scope.
Global Scope
Variables declared outside of any function have global scope and can be accessed from anywhere in the code.
Example: Global Scope
let globalVar = "I am global";
function showGlobalVar() {
console.log(globalVar); // Accessible
}
showGlobalVar(); // Output: I am global
Local Scope
Variables declared within a function have local scope and are only accessible within that function.
Example: Local Scope
function localScopeExample() {
let localVar = "I am local";
console.log(localVar); // Accessible
}
localScopeExample(); // Output: I am local
console.log(localVar); // Error: localVar is not defined
Block Scope
ES6 introduced block scope with let and const, allowing variables to be confined to the block they are declared in.
Example: Block Scope
if (true) {
let blockVar = "I am block scoped";
console.log(blockVar); // Accessible
}
console.log(blockVar); // Error: blockVar is not defined
Functions as First-Class Citizens
In JavaScript, functions are first-class citizens, meaning they can be assigned to variables, passed as arguments, and returned from other functions.
Passing Functions as Arguments
You can pass functions as arguments to other functions, allowing for flexible code structures and operations.
Example: Passing Functions
function executeFunction(fn, value) {
return fn(value);
}
function square(x) {
return x * x;
}
console.log(executeFunction(square, 5)); // Output: 25
Returning Functions
Functions can also return other functions, enabling the creation of higher-order functions.
Example: Returning Functions
function createMultiplier(multiplier) {
return function (x) {
return x * multiplier;
};
}
const double = createMultiplier(2);
console.log(double(4)); // Output: 8
FAQs
1. What is a function in JavaScript?
A function is a block of code designed to perform a specific task, which can be reused throughout your program.
2. What are arrow functions?
Arrow functions are a concise way to write anonymous functions using the => syntax.
3. What is the difference between global and local scope?
Global scope variables are accessible anywhere in the code, while local scope variables are confined to the function they are declared in.
One-Liner Questions
• What is a function expression?
A function expression defines a function within an expression and can be assigned to a variable.
• What is block scope in JavaScript?
Block scope confines variables to the block they are declared in, using let or const.
Coding Problems
1. Problem 1: Factorial Calculation
• Write a function to calculate the factorial of a number using recursion.
function factorial(n) {
if (n === 0) return 1;
return n * factorial(n - 1);
}
console.log(factorial(5)); // Output: 120
2. Problem 2: Sum of Squares
• Create a function that returns the sum of squares of all numbers in an array.
function sumOfSquares(arr) {
return arr.reduce((sum, num) => sum + num * num, 0);
}
console.log(sumOfSquares([1, 2, 3, 4])); // Output: 30
3. Problem 3: Function Composition
• Implement a function that composes two functions together.
function compose(f, g) {
return function (x) {
return f(g(x));
};
}
const addOne = (x) => x + 1;
const square = (x) => x * x;
const addOneThenSquare = compose(square, addOne);
console.log(addOneThenSquare(2)); // Output: 9
External Links
1. JavaScript Functions - MDN Web Docs - Comprehensive Guide to JavaScript Functions
2. JavaScript Function Basics - W3Schools - JavaScript Function Basics
3. Understanding Scope in JavaScript - Codecademy - Understanding JavaScript Scope
Commenti