搜尋
首頁web前端js教程掌握 JavaScript 函數:開發人員綜合指南

Mastering JavaScript Functions: A Comprehensive Guide for Developers

Fungsi JavaScript

Fungsi JavaScript ialah blok kod yang direka untuk melaksanakan tugas tertentu.
Fungsi JavaScript dilaksanakan apabila "sesuatu" memanggilnya (memanggilnya).

Fungsi JavaScript ialah konsep asas dalam bahasa, membolehkan anda merangkum kod ke dalam blok boleh guna semula. Berikut ialah gambaran keseluruhan:

Pengisytiharan Fungsi

Ini ialah cara yang paling biasa untuk menentukan fungsi. Anda menggunakan kata kunci fungsi diikuti dengan nama dan blok kod.

function greet(name) {
    return `Hello, ${name}!`;
}

console.log(greet('Alice')); // Outputs: Hello, Alice!

1. Ungkapan Fungsi

Fungsi juga boleh ditakrifkan sebagai ungkapan dan diberikan kepada pembolehubah. Ini boleh berguna untuk mencipta fungsi tanpa nama atau apabila anda ingin menyampaikan fungsi sebagai argumen.

const greet = function(name) {
    return `Hello, ${name}!`;
};

console.log(greet('Bob')); // Outputs: Hello, Bob!

2. Fungsi Anak Panah

Diperkenalkan dalam ES6, fungsi anak panah menawarkan sintaks yang lebih pendek. Ia amat berguna untuk fungsi sebaris dan mempunyai gelagat yang berbeza untuk kata kunci ini.

const greet = (name) => `Hello, ${name}!`;

console.log(greet('Charlie')); // Outputs: Hello, Charlie!

3. Fungsi dengan Parameter Lalai

Anda boleh memberikan nilai lalai untuk parameter fungsi, yang akan digunakan jika tiada nilai atau undefined diluluskan.

function greet(name = 'Guest') {
    return `Hello, ${name}!`;
}

console.log(greet()); // Outputs: Hello, Guest!
console.log(greet('Dana')); // Outputs: Hello, Dana!

4. Parameter Rehat

Sintaks ... membolehkan anda mewakili bilangan argumen yang tidak ditentukan sebagai tatasusunan.

function sum(...numbers) {
    return numbers.reduce((total, num) => total + num, 0);
}

console.log(sum(1, 2, 3)); // Outputs: 6
console.log(sum(1, 2, 3, 4, 5)); // Outputs: 15

5. Skop Fungsi

Fungsi dalam JavaScript mempunyai skopnya sendiri. Pembolehubah yang diisytiharkan di dalam fungsi tidak boleh diakses dari luar.

function example() {
    let localVar = 'I am local';
    console.log(localVar); // Outputs: I am local
}

console.log(localVar); // ReferenceError: localVar is not defined

6. Memulangkan Nilai

Fungsi boleh mengembalikan nilai menggunakan kata kunci pulangan. Jika tiada pernyataan pemulangan digunakan, fungsi itu kembali tidak ditentukan secara lalai.

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

console.log(add(5, 3)); // Outputs: 8

7. Ungkapan Fungsi Dipanggil Serta-merta (IIFE)

IIFE ialah fungsi yang berjalan sebaik sahaja ia ditakrifkan. Ia sering digunakan untuk mencipta skop baharu.

(function() {
    console.log('I am an IIFE');
})();

8. Pembina Fungsi

Walaupun tidak biasa digunakan, anda boleh mencipta fungsi menggunakan pembina Fungsi.

const greet = new Function('name', 'return `Hello, ${name}!`');
console.log(greet('Eve')); // Outputs: Hello, Eve!

9. Penutupan

Penutupan ialah fungsi yang mempunyai akses kepada pembolehubah daripada skop fungsi lain. Ini ialah ciri hebat dalam JavaScript.

function makeCounter() {
    let count = 0;
    return function() {
        count += 1;
        return count;
    };
}

const counter = makeCounter();
console.log(counter()); // Outputs: 1
console.log(counter()); // Outputs: 2

Jangan ragu untuk menyelami lebih mendalam mana-mana konsep ini atau tanya jika anda mempunyai soalan khusus!

Fungsi JavaScript mempunyai pelbagai sintaks, setiap satu berguna dalam konteks yang berbeza. Berikut ialah gambaran keseluruhan terperinci:

Parameter Fungsi

Parameter fungsi JavaScript mentakrifkan nilai yang boleh diterima oleh fungsi apabila ia dipanggil. Parameter ini membolehkan fungsi menjadi lebih fleksibel dan boleh digunakan semula. Berikut ialah pandangan terperinci tentang pelbagai aspek parameter fungsi JavaScript:

1. Parameter Asas

Apabila mentakrifkan fungsi, anda menentukan parameter dalam definisi fungsi. Apabila fungsi dipanggil, anda memberikan hujah yang sepadan dengan parameter ini.

Contoh:

function greet(name, age) {
    console.log(`Hello, ${name}! You are ${age} years old.`);
}

greet('Alice', 30); // Outputs: Hello, Alice! You are 30 years old.

2. Parameter Lalai

Anda boleh menetapkan nilai lalai kepada parameter. Jika tiada nilai atau undefined diluluskan untuk parameter ini, nilai lalai akan digunakan.

Contoh:

function greet(name = 'Guest', age = 18) {
    console.log(`Hello, ${name}! You are ${age} years old.`);
}

greet(); // Outputs: Hello, Guest! You are 18 years old.
greet('Bob'); // Outputs: Hello, Bob! You are 18 years old.
greet('Charlie', 25); // Outputs: Hello, Charlie! You are 25 years old.

3. Parameter Rehat

Parameter rehat membolehkan anda mewakili bilangan argumen yang tidak ditentukan sebagai tatasusunan. Ini berguna apabila anda tidak tahu berapa banyak hujah yang akan diluluskan.

Contoh:

function sum(...numbers) {
    return numbers.reduce((total, num) => total + num, 0);
}

console.log(sum(1, 2, 3)); // Outputs: 6
console.log(sum(1, 2, 3, 4, 5)); // Outputs: 15

4. Pemusnahan Parameter

Penstrukturan membolehkan anda membongkar nilai daripada tatasusunan atau sifat daripada objek ke dalam pembolehubah berbeza secara terus dalam parameter fungsi.

Contoh dengan Pemusnahan Objek:

function displayInfo({ name, age }) {
    console.log(`Name: ${name}, Age: ${age}`);
}

const person = { name: 'Alice', age: 30 };
displayInfo(person); // Outputs: Name: Alice, Age: 30

Contoh dengan Pemusnahan Tatasusunan:

function sum([a, b]) {
    return a + b;
}

console.log(sum([5, 10])); // Outputs: 15

5. Parameter Susunan dan Rehat Parameter

Apabila menggunakan kedua-dua parameter biasa dan parameter rehat, parameter rehat mestilah parameter terakhir dalam definisi fungsi.

Contoh:

function logInfo(name, age, ...additionalInfo) {
    console.log(`Name: ${name}, Age: ${age}`);
    console.log('Additional Info:', additionalInfo);
}

logInfo('Alice', 30, 'Engineer', 'Loves JavaScript'); 
// Outputs:
// Name: Alice, Age: 30
// Additional Info: ['Engineer', 'Loves JavaScript']

6. Parameter Dinamakan (Argumen Objek)

Menggunakan objek sebagai parameter membolehkan anda menghantar argumen bernama. Ini amat berguna untuk fungsi dengan banyak parameter atau parameter pilihan.

Contoh:

function createProfile({ name, age, job }) {
    console.log(`Name: ${name}, Age: ${age}, Job: ${job}`);
}

createProfile({ name: 'Alice', age: 30, job: 'Developer' });
// Outputs: Name: Alice, Age: 30, Job: Developer

7. Function Overloading

JavaScript does not support function overloading in the traditional sense (same function name with different parameter lists). Instead, you can handle different parameter scenarios inside a function.

Example:

function process(value1, value2) {
    if (value2 === undefined) {
        console.log(`Processing single value: ${value1}`);
    } else {
        console.log(`Processing two values: ${value1} and ${value2}`);
    }
}

process(5); // Outputs: Processing single value: 5
process(5, 10); // Outputs: Processing two values: 5 and 10

8. Arguments Object

In non-arrow functions, the arguments object provides access to all the arguments passed to a function. It is an array-like object but does not have array methods.

Example:

function printArguments() {
    for (let i = 0; i 



<h3>
  
  
  <strong>Function Call</strong>
</h3>

<p>This is the standard way to invoke a function by simply calling its name followed by parentheses.</p>

<p><strong>Example:</strong><br>
</p>

<pre class="brush:php;toolbar:false">function greet(name) {
    console.log(`Hello, ${name}!`);
}

greet('Alice'); // Outputs: Hello, Alice!

1. Method Invocation

When a function is a property of an object, it's called a method. You invoke it using dot notation or bracket notation.

Example:

const person = {
    name: 'Bob',
    greet: function() {
        console.log(`Hello, ${this.name}!`);
    }
};

person.greet(); // Outputs: Hello, Bob!

2. Constructor Invocation

Functions invoked with the new keyword act as constructors and create new instances of objects. In this case, this refers to the newly created object.

Example:

function Person(name) {
    this.name = name;
}

const person1 = new Person('Charlie');
console.log(person1.name); // Outputs: Charlie

3. Function Invocation Using call and apply

The call and apply methods allow you to invoke a function with a specific this context and arguments.

  • call Method: Passes arguments separately.

    Example:

    function greet(greeting, punctuation) {
        console.log(`${greeting}, ${this.name}${punctuation}`);
    }
    
    const person = { name: 'Dana' };
    greet.call(person, 'Hello', '!'); // Outputs: Hello, Dana!
    
  • apply Method: Passes arguments as an array.

    Example:

    function greet(greeting, punctuation) {
        console.log(`${greeting}, ${this.name}${punctuation}`);
    }
    
    const person = { name: 'Eva' };
    greet.apply(person, ['Hi', '.']); // Outputs: Hi, Eva.
    

4. Arrow Functions Invocation

Arrow functions do not have their own this context; they inherit this from the surrounding scope.

Example:

const person = {
    name: 'Frank',
    greet: () => {
        console.log(`Hello, ${this.name}!`); // 'this' refers to the surrounding scope, not the 'person' object
    }
};

person.greet(); // Outputs: Hello, undefined!

5. Using bind

The bind method creates a new function with a specific this context and optional arguments.

Example:

function greet(greeting) {
    console.log(`${greeting}, ${this.name}!`);
}

const person = { name: 'Grace' };
const greetPerson = greet.bind(person, 'Welcome');
greetPerson(); // Outputs: Welcome, Grace!

6. Immediately Invoked Function Expression (IIFE)

An IIFE is a function expression that is immediately executed after its definition.

Example:

(function() {
    console.log('I am an IIFE!');
})(); // Outputs: I am an IIFE!

7. Dynamic Function Invocation

JavaScript functions can be dynamically invoked using the Function constructor or the eval function, though these approaches are less common and generally discouraged due to security and performance concerns.

Example Using Function Constructor:

const dynamicFunc = new Function('a', 'b', 'return a + b;');
console.log(dynamicFunc(2, 3)); // Outputs: 5

Example Using eval:

const code = 'console.log("Hello from eval!")';
eval(code); // Outputs: Hello from eval!

Function Return

In JavaScript, a function's return statement is crucial for specifying the output or result of the function. Here’s a detailed look at how return works and its various nuances:

1. Basic Usage

A function can return a value using the return statement. When the return statement is executed, the function terminates, and the specified value is sent back to the caller.

Example:

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

const result = add(5, 3);
console.log(result); // Outputs: 8

2. Returning Early

A function can use return to exit early before reaching the end of its block. This is often used to handle special cases or invalid inputs.

Example:

function divide(a, b) {
    if (b === 0) {
        return 'Error: Division by zero';
    }
    return a / b;
}

console.log(divide(10, 2)); // Outputs: 5
console.log(divide(10, 0)); // Outputs: Error: Division by zero

3. Implicit Return (Arrow Functions)

In arrow functions with a single expression, the return keyword can be omitted. The expression is automatically returned.

Example:

const multiply = (a, b) => a * b;

console.log(multiply(4, 5)); // Outputs: 20

4. Returning Multiple Values

JavaScript functions can only return one value. However, you can return multiple values by using an object or array.

Using an Object:

function getPerson() {
    return {
        name: 'Alice',
        age: 30
    };
}

const person = getPerson();
console.log(person.name); // Outputs: Alice
console.log(person.age);  // Outputs: 30

Using an Array:

function getCoordinates() {
    return [40.7128, -74.0060]; // latitude and longitude
}

const [latitude, longitude] = getCoordinates();
console.log(latitude);  // Outputs: 40.7128
console.log(longitude); // Outputs: -74.0060

5. Returning undefined

If a function does not have a return statement, or if the return statement does not specify a value, the function returns undefined.

Example:

function greet(name) {
    console.log(`Hello, ${name}!`);
    // No return statement
}

const result = greet('Bob');
console.log(result); // Outputs: undefined

6. Returning from Recursive Functions

In recursive functions, the return statement is used to return values at each level of recursion.

Example:

function factorial(n) {
    if (n === 0) {
        return 1;
    }
    return n * factorial(n - 1);
}

console.log(factorial(5)); // Outputs: 120

7. Returning from Constructors

When using constructors (functions invoked with new), the return statement can be used to return a different object. If no return statement is provided, the newly created instance is returned by default.

Example:

function Person(name) {
    this.name = name;
    // Optional return statement
    // return { name: name }; // This would override the default instance
}

const person = new Person('Alice');
console.log(person.name); // Outputs: Alice

8. Returning from Closures

Functions within closures can return values that depend on variables from their outer function.

Example:

function createCounter() {
    let count = 0;
    return function() {
        count += 1;
        return count;
    };
}

const counter = createCounter();
console.log(counter()); // Outputs: 1
console.log(counter()); // Outputs: 2

Functions Used as Variable Values

In JavaScript, functions can be assigned to variables, which allows them to be treated as first-class objects. This means functions can be passed around as values, stored in variables, and used in various ways. Here’s a comprehensive look at how functions can be used as variable values:

1. Assigning Functions to Variables

You can assign a function to a variable, effectively creating a function expression.

Example:

const greet = function(name) {
    return `Hello, ${name}!`;
};

console.log(greet('Alice')); // Outputs: Hello, Alice!

In this example, greet is a variable that holds a function. The function can be called using greet().

2. Function Expressions

Function expressions are functions that are defined inside expressions and can be assigned to variables.

Example:

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

console.log(add(2, 3)); // Outputs: 5

3. Arrow Functions as Variable Values

Arrow functions provide a concise syntax and can also be assigned to variables.

Example:

const multiply = (x, y) => x * y;

console.log(multiply(4, 5)); // Outputs: 20

4. Passing Functions as Arguments

Functions assigned to variables can be passed as arguments to other functions. This is a common pattern in JavaScript.

Example:

function executeFunction(fn, value) {
    return fn(value);
}

const double = x => x * 2;

console.log(executeFunction(double, 5)); // Outputs: 10

5. Returning Functions from Other Functions

Functions can return other functions. This technique is used in functional programming and closures.

Example:

function createMultiplier(factor) {
    return function(x) {
        return x * factor;
    };
}

const double = createMultiplier(2);
const triple = createMultiplier(3);

console.log(double(5)); // Outputs: 10
console.log(triple(5)); // Outputs: 15

6. Storing Functions in Arrays

Functions can be stored in arrays and accessed or invoked using array indices.

Example:

const functions = [
    function(a) { return a + 1; },
    function(a) { return a * 2; },
    function(a) { return a - 3; }
];

console.log(functions ); // Outputs: 6
console.log(functions ); // Outputs: 10
console.log(functions ); // Outputs: 2

7. Storing Functions in Objects

Functions can be properties of objects and accessed using dot notation or bracket notation.

Example:

const math = {
    add: function(a, b) { return a + b; },
    subtract: function(a, b) { return a - b; }
};

console.log(math.add(10, 5)); // Outputs: 15
console.log(math.subtract(10, 5)); // Outputs: 5

8. Using Functions as Event Handlers

In event-driven programming, functions are often assigned to variables and used as event handlers.

Example:

const button = document.getElementById('myButton');

const handleClick = () => {
    alert('Button clicked!');
};

button.addEventListener('click', handleClick);

9. Using Functions as Callbacks

Functions assigned to variables can be passed as callbacks to other functions.

Example:

function processArray(arr, callback) {
    return arr.map(callback);
}

const numbers = [1, 2, 3, 4, 5];
const squaredNumbers = processArray(numbers, x => x * x);

console.log(squaredNumbers); // Outputs: [1, 4, 9, 16, 25]

10. Dynamic Function Creation

Functions can be created dynamically and assigned to variables, such as using the Function constructor.

Example:

const createAdder = new Function('a', 'b', 'return a + b;');

console.log(createAdder(2, 3)); // Outputs: 5

Local Variables

Variables declared within a JavaScript function, become LOCAL to the function.

Local variables can only be accessed from within the function.

// code here can NOT use carName

function myFunction() {
  let carName = "Volvo";
  // code here CAN use carName
}

// code here can NOT use carName

Function Invocation

In JavaScript, function invocation refers to the various ways a function can be executed. The manner in which a function is invoked affects its behavior, particularly the this context and the function’s scope. Here’s a detailed overview of different methods of function invocation:

1. Direct Invocation

The most straightforward way to invoke a function is to call it directly by using its name followed by parentheses.

Example:

function greet(name) {
    console.log(`Hello, ${name}!`);
}

greet('Alice'); // Outputs: Hello, Alice!

2. Method Invocation

When a function is a property of an object, it is called a method. It is invoked using the dot notation or bracket notation on the object.

Example:

const person = {
    name: 'Bob',
    greet: function() {
        console.log(`Hello, ${this.name}!`);
    }
};

person.greet(); // Outputs: Hello, Bob!

3. Constructor Invocation

Functions invoked with the new keyword are treated as constructors. They create a new instance of an object. In this context, this refers to the newly created object.

Example:

function Person(name) {
    this.name = name;
}

const person1 = new Person('Charlie');
console.log(person1.name); // Outputs: Charlie

4. Using call() Method

The call() method allows you to invoke a function with a specific this context and individual arguments. It’s useful for borrowing methods from other objects.

Example:

function greet(greeting, punctuation) {
    console.log(`${greeting}, ${this.name}${punctuation}`);
}

const person = { name: 'Dana' };
greet.call(person, 'Hello', '!'); // Outputs: Hello, Dana!

5. Using apply() Method

The apply() method is similar to call(), but it takes arguments as an array. This method is useful when you have an array of arguments that need to be passed to the function.

Example:

function greet(greeting, punctuation) {
    console.log(`${greeting}, ${this.name}${punctuation}`);
}

const person = { name: 'Eva' };
greet.apply(person, ['Hi', '.']); // Outputs: Hi, Eva.

6. Using bind() Method

The bind() method creates a new function with a specific this value and optionally pre-set arguments. This new function can be invoked later.

Example:

function greet(greeting, punctuation) {
    console.log(`${greeting}, ${this.name}${punctuation}`);
}

const person = { name: 'Frank' };
const boundGreet = greet.bind(person, 'Welcome');
boundGreet('!'); // Outputs: Welcome, Frank!

7. Immediately Invoked Function Expression (IIFE)

An IIFE is a function expression that is immediately executed after its definition. It’s often used to create a new scope to avoid polluting the global namespace.

Example:

(function() {
    console.log('I am an IIFE!');
})(); // Outputs: I am an IIFE!

8. Arrow Functions

Arrow functions are a concise syntax for writing functions and they don’t have their own this. Instead, this is inherited from the surrounding lexical scope.

Example:

const person = {
    name: 'Grace',
    greet: () => {
        console.log(`Hello, ${this.name}!`); // 'this' refers to the surrounding scope, not the 'person' object
    }
};

person.greet(); // Outputs: Hello, undefined!

9. Using Function Constructor

You can dynamically create functions using the Function constructor, though it is generally less common and less safe due to potential performance and security issues.

Example:

const dynamicFunc = new Function('a', 'b', 'return a + b;');
console.log(dynamicFunc(2, 3)); // Outputs: 5

10. Function Expressions and Assignments

Functions can be assigned to variables and then invoked. This includes both named and anonymous functions.

Example:

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

console.log(add(2, 3)); // Outputs: 5

Function apply()

The apply() method in JavaScript is used to call a function with a given this value and arguments provided as an array (or an array-like object). It’s part of the Function.prototype and is very useful for invoking functions with a specific context and arguments.

Here’s a detailed breakdown of how apply() works:

Syntax

func.apply(thisArg, [argsArray])
  • func: The function you want to call.
  • thisArg: The value to use as this when calling the function.
  • argsArray: An array or array-like object of arguments to pass to the function.

Example

Suppose you have a function that adds two numbers:

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

You can use apply() to call this function with a specific this value (though in this simple case, this isn’t used) and an array of arguments:

const result = add.apply(null, [3, 4]);
console.log(result); // Outputs: 7

Using apply() with this

When calling methods on objects, apply() can be used to specify the this value. This is particularly useful for methods that need to be called in the context of a different object.

Example:

const person = {
    name: 'Alice',
    greet: function(greeting) {
        return `${greeting}, ${this.name}!`;
    }
};

const anotherPerson = {
    name: 'Bob'
};

console.log(person.greet.apply(anotherPerson, ['Hello'])); // Outputs: Hello, Bob!

In this example, greet is called on anotherPerson instead of the person object.

Using apply() with Math Methods

apply() is often used with Math methods to pass an array of numbers as individual arguments.

Example:

const numbers = [5, 6, 2, 8, 3];
const maxNumber = Math.max.apply(null, numbers);
console.log(maxNumber); // Outputs: 8

In this example, Math.max is called with the numbers in the array spread out as individual arguments.

Comparison with call()

The call() method is similar to apply(), but it takes arguments individually rather than as an array.

Example with call():

function greet(greeting, punctuation) {
    return `${greeting}, ${this.name}${punctuation}`;
}

const person = { name: 'Charlie' };

console.log(greet.call(person, 'Hi', '!')); // Outputs: Hi, Charlie!

Function bind()

The bind() method in JavaScript is used to create a new function with a specific this context and, optionally, pre-set arguments. This is particularly useful for setting the context of this when passing functions around or for partial function application.

Here’s a detailed overview of how bind() works and how it can be used:

Syntax

function.bind(thisArg, arg1, arg2, ...)
  • thisArg: The value to which this should be bound in the new function.
  • arg1, arg2, ...: Optional parameters that are pre-set and will be provided to the function when it is called.

Example 1: Basic Usage

The most basic use of bind() is to create a new function where this is fixed to a specific value.

function greet(greeting) {
    console.log(`${greeting}, ${this.name}!`);
}

const person = { name: 'Alice' };
const boundGreet = greet.bind(person, 'Hello');
boundGreet(); // Outputs: Hello, Alice!

In this example, boundGreet is a new function created by bind() where this is permanently set to the person object.

Example 2: Partial Application

bind() can also be used for partial application, where you pre-set some arguments and leave others to be provided later.

function multiply(a, b) {
    return a * b;
}

const double = multiply.bind(null, 2);
console.log(double(5)); // Outputs: 10

In this example, double is a function that multiplies its argument by 2. The bind() method creates this new function by fixing 2 as the first argument.

Example 3: Using with Methods

bind() is particularly useful when dealing with methods that need to be used as callbacks but must retain the correct this context.

Example with Event Handlers:

class Counter {
    constructor() {
        this.count = 0;
        this.increment = this.increment.bind(this); // Fixes 'this' context
    }

    increment() {
        this.count += 1;
        console.log(this.count);
    }
}

const counter = new Counter();
document.getElementById('incrementButton').addEventListener('click', counter.increment);

In this example, increment needs to have the correct this context when called as an event handler. By using bind(), this in increment correctly refers to the Counter instance.

Example 4: Multiple Arguments

You can also use bind() to fix multiple arguments.

function displayInfo(age, occupation) {
    console.log(`Name: ${this.name}, Age: ${age}, Occupation: ${occupation}`);
}

const person = { name: 'Bob' };
const boundDisplayInfo = displayInfo.bind(person, 30);
boundDisplayInfo('Engineer'); // Outputs: Name: Bob, Age: 30, Occupation: Engineer

Here, boundDisplayInfo has this set to person and the first argument (age) is pre-set to 30.

Differences from call() and apply()

While call() and apply() can also set the this context and pass arguments, they invoke the function immediately. bind() creates a new function that, when called, will have its this set to the specified value and will use the provided arguments.

  • call(): Invokes the function immediately with a specified this and arguments.
  function showInfo(age, occupation) {
      console.log(`Name: ${this.name}, Age: ${age}, Occupation: ${occupation}`);
  }

  const person = { name: 'Charlie' };
  showInfo.call(person, 28, 'Teacher'); // Outputs: Name: Charlie, Age: 28, Occupation: Teacher
  • apply(): Similar to call(), but arguments are passed as an array.
  function showInfo(age, occupation) {
      console.log(`Name: ${this.name}, Age: ${age}, Occupation: ${occupation}`);
  }

  const person = { name: 'Dana' };
  showInfo.apply(person, [32, 'Artist']); // Outputs: Name: Dana, Age: 32, Occupation: Artist
  • bind(): Returns a new function with this and optionally arguments set.
  function showInfo(age, occupation) {
      console.log(`Name: ${this.name}, Age: ${age}, Occupation: ${occupation}`);
  }

  const person = { name: 'Eva' };
  const boundShowInfo = showInfo.bind(person, 40);
  boundShowInfo('Scientist'); // Outputs: Name: Eva, Age: 40, Occupation: Scientist

Closures

In JavaScript, a closure is a powerful concept where a function retains access to its lexical scope even after the function has finished executing. Closures allow functions to access variables from an outer scope that have already executed, which is useful for creating private variables, factory functions, and more.

Here’s a detailed overview of closures:

What is a Closure?

A closure is created when a function is defined inside another function, and the inner function retains access to the outer function’s variables. This allows the inner function to "close over" the variables of its outer function.

Example:

function outerFunction() {
    let outerVariable = 'I am from outer function';

    function innerFunction() {
        console.log(outerVariable); // Inner function has access to outerVariable
    }

    return innerFunction;
}

const closureFunction = outerFunction();
closureFunction(); // Outputs: I am from outer function

In this example:

  • outerFunction returns innerFunction.
  • innerFunction retains access to outerVariable even after outerFunction has finished executing.
  • The variable outerVariable is preserved in the closure.

Characteristics of Closures

  1. Access to Outer Variables: Closures can access variables from their containing (outer) scope even after the outer function has completed execution.

  2. Encapsulation: Closures can be used to create private variables and methods, which are not directly accessible from outside the closure.

  3. Persistent State: Closures can maintain state across multiple invocations.

Examples of Closures

1. Private Variables:

Closures are commonly used to create private variables in JavaScript, which are not accessible from outside the closure.

function createCounter() {
    let count = 0; // Private variable

    return function() {
        count += 1;
        console.log(count);
    };
}

const counter = createCounter();
counter(); // Outputs: 1
counter(); // Outputs: 2
counter(); // Outputs: 3

In this example:

  • count is a private variable that is not directly accessible from outside createCounter.
  • The returned function is a closure that maintains access to count.

2. Function Factories:

Closures can be used to create factory functions that generate other functions with specific behavior.

function createGreeting(greeting) {
    return function(name) {
        console.log(`${greeting}, ${name}!`);
    };
}

const sayHello = createGreeting('Hello');
const sayGoodbye = createGreeting('Goodbye');

sayHello('Alice'); // Outputs: Hello, Alice!
sayGoodbye('Bob'); // Outputs: Goodbye, Bob!

In this example:

  • createGreeting is a function factory that returns a function with a specific greeting.
  • The returned function retains access to the greeting variable.

3. Event Handlers:

Closures are often used in event handlers to preserve context and state.

function setupButton(buttonId) {
    let clickCount = 0;

    document.getElementById(buttonId).addEventListener('click', function() {
        clickCount += 1;
        console.log(`Button clicked ${clickCount} times`);
    });
}

setupButton('myButton');

In this example:

  • clickCount is a private variable that is maintained across multiple button clicks.
  • The event handler function is a closure that retains access to clickCount.

Closures and this Context

Closures can sometimes lead to confusion with the this context, especially in object-oriented programming. Arrow functions, which do not have their own this, are often used in conjunction with closures to avoid issues related to this.

Example with Arrow Functions:

function Counter() {
    this.count = 0;

    setInterval(() => {
        this.count += 1; // Arrow function does not have its own 'this'
        console.log(this.count);
    }, 1000);
}

const counter = new Counter();

In this example:

  • The arrow function inside setInterval retains the this context of the Counter instance, allowing access to this.count.

以上是掌握 JavaScript 函數:開發人員綜合指南的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
Java vs JavaScript:開發人員的詳細比較Java vs JavaScript:開發人員的詳細比較May 16, 2025 am 12:01 AM

javaandjavascriptaredistinctlanguages:javaisusedforenterpriseandmobileapps,while javascriptifforInteractiveWebpages.1)JavaisComcompoppored,statieldinglationallyTypted,statilly tater astrunsonjvm.2)

JavaScript數據類型:瀏覽器和nodejs之間是否有區別?JavaScript數據類型:瀏覽器和nodejs之間是否有區別?May 14, 2025 am 12:15 AM

JavaScript核心數據類型在瀏覽器和Node.js中一致,但處理方式和額外類型有所不同。 1)全局對像在瀏覽器中為window,在Node.js中為global。 2)Node.js獨有Buffer對象,用於處理二進制數據。 3)性能和時間處理在兩者間也有差異,需根據環境調整代碼。

JavaScript評論:使用//和 / * * / * / * /JavaScript評論:使用//和 / * * / * / * /May 13, 2025 pm 03:49 PM

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python vs. JavaScript:開發人員的比較分析Python vs. JavaScript:開發人員的比較分析May 09, 2025 am 12:22 AM

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

Python vs. JavaScript:選擇合適的工具Python vs. JavaScript:選擇合適的工具May 08, 2025 am 12:10 AM

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript:了解每個的優勢Python和JavaScript:了解每個的優勢May 06, 2025 am 12:15 AM

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

JavaScript的核心:它是在C還是C上構建的?JavaScript的核心:它是在C還是C上構建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript應用程序:從前端到後端JavaScript應用程序:從前端到後端May 04, 2025 am 12:12 AM

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

北端:融合系統,解釋
1 個月前By尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
4 週前By尊渡假赌尊渡假赌尊渡假赌
<🎜>掩蓋:探險33-如何獲得完美的色度催化劑
2 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。