Tổng quan về function trong JavaScript
– JavaScript cung cấp các hàm (functions) tương tự như hầu hết các ngôn ngữ lập trình.
– Trong JavaScript, bạn có thể sử dụng các functions để xác định các khối lệnh, đặt tên cho chúng và thực hiện chúng nhiều lần tùy thích.
- Cách định nghĩa hàm JavaScript
- Anonymous Function Hàm ẩn danh, hàm không tên
- Nested Function Hàm có thể lồng vào nhau
- Return Value Giá trị trả về của hàm JavaScript
- Hàm dựng, hàm tạo Function() Constructor
- Function Hoisting
- Cách một hàm tự gọi chính nó
- Function có thể được sử dụng làm giá trị
- Function là một Object
1. Cách định nghĩa hàm JavaScript
– Một hàm JavaScript có thể được định nghĩa bằng cách sử dụng từ khóa function
.
– Bạn có thể sử dụng khai báo hàm (function declaration) hoặc biểu thức hàm (function expression).
1.1. Sử dụng khai báo hàm (function declaration)
■ Cú pháp:
// Định nghĩa hàm function functionName(parameters) { // các lệnh thực thi } // Gọi hàm functionName();
■ Ví dụ:
return a * b;
}
myFunction(4, 3); // return 12[/code] Try it »
– Dấu chấm phẩy được sử dụng để phân tách các câu lệnh JavaScript có thể thực thi.
– Vì một khai báo hàm không phải là một câu lệnh thực thi được, nên không cần kết thúc nó bằng một dấu chấm phẩy.
1.2. Sử dụng biểu thức hàm (function expression)
– Một hàm JavaScript cũng có thể được định nghĩa bằng cách sử dụng một biểu thức (expression).
– Biểu thức hàm có thể được lưu trữ trong một biến:
Ví dụ 1:
[code language=”javascript”]var x = function (a, b) {return a * b};[/code] Try it »– Sau khi một hàm (function expression) được lưu trữ trong biến, biến có thể được sử dụng như một hàm.
– Các hàm được lưu trong các biến không cần tên hàm. Chúng luôn được invoked (called) bằng cách sử dụng tên biến.
Ví dụ 2:
[code language=”javascript”]var x = function (a, b) {return a * b};var y = x(4, 3); // return 12[/code] Try it »
Ví dụ 3:
[code language=”javascript”]var add = function sum(val1, val2) {return val1 + val2;
};
var result1 = add(10,20);
var result2 = sum(10,20); // not valid[/code]
Try it »
Hàm trên là một phần câu lệnh thực thi được, vì vậy nó kết thúc bằng dấu chấm phẩy.
2. Anonymous Function Hàm ẩn danh, hàm không tên
– Các hàm ở ví dụ 2 và 3 thực chất là các hàm ẩn danh (anonymous function – hàm không có tên).
– JavaScript cho phép chúng ta định nghĩa một hàm mà không có bất kỳ tên nào. Hàm chưa được đặt tên này được gọi là hàm ẩn danh – anonymous function. Hàm ẩn danh phải được gán cho một biến.
Ví dụ:
[code language=”javascript”]var showMessage = function (){alert("Hello World!");
};
showMessage();
var sayHello = function (firstName) {
alert("Hello " + firstName);
};
showMessage();
sayHello("Minh Hoàng Blog!");[/code] Try it »
Anonymous Function rất hữu ích khi passing callback function, creating closure hoặc function expression được gọi ngay lập tức.
3. Nested Function Hàm có thể lồng vào nhau
– Trong JavaScript, một hàm có thể có một hoặc nhiều hàm bên trong (inner functions).
– Các hàm lồng nhau (nested functions) này nằm trong phạm vi của hàm bên ngoài (outer function).
– Inner function có thể truy cập các biến (variables) và tham số (parameters) của outer function. Tuy nhiên, outer function không thể truy cập các biến được định nghĩa bên trong các inner functions.
Ví dụ:
[code language=”javascript”]function showMessage(firstName){
// Biến x1 của outer function
var x1 = "Minh Hoàng Blog";
function sayHello() {
document.getElementById("demo1").innerHTML = x1; // Minh Hoàng Blog
// Biến x2 của inner function
var x2 = "www.minhhn.com";
alert("Hello " + firstName);
}
document.getElementById("demo2").innerHTML = x2; // Error: ReferenceError, x2 is not defined.
return sayHello();
}
showMessage("World!");[/code] Try it »
4. Return Value Giá trị trả về của hàm JavaScript
– Một hàm có thể trả về zero (0) hoặc một giá trị bằng cách sử dụng từ khóa return
.
Ví dụ: Hàm trả về giá trị (Return value from a Function)
[code language=”javascript”]// Hàm có returnfunction sum(val1, val2) {
return val1 + val2;
};
sum(10,20); // 30
// Hàm không return
function multiply(val1, val2) {
console.log( val1 * val2);
};
multiply(10,20); // undefined[/code] Try it »
– Trong ví dụ trên, hàm Sum thực hiện cộng 2 giá trị val1 và val2 và return
kết quả. Vì vậy, khi gọi có thể nhận được giá trị trả về là 30. Nhưng ở hàm thứ hai Multiply không trả về bất kỳ giá trị nào, do đó kết quả nhận được sẽ là undefined.
Ví dụ: Hàm trả về một hàm (Function returning from a Function)
[code language=”javascript”]function multiply(x) { function fn(y)
{
return x * y;
}
return fn;
}
var calc = multiply(3);
calc(2); // 6
calc(3); // 9[/code]
Try it »
5. Hàm dựng, hàm tạo Function() Constructor
– Như chúng ta đã thấy trong các ví dụ trên, các hàm JavaScript được định nghĩa với từ khóa function
.
– Các hàm cũng có thể được định nghĩa bằng function constructor được xây dựng sẵn (built-in) trong JavaScript là Function().
Ví dụ:
[code language=”javascript”]var myFunction = new Function("a", "b", "return a * b");var x = myFunction(4, 3); // 12[/code] Try it »
– Trong thực tế, bạn không cần sử dụng function constructor. Ví dụ trên giống với cách viết sau:
Ví dụ:
[code language=”javascript”]var myFunction = function (a, b) {return a * b};var x = myFunction(4, 3); // 12[/code] Try it »
Trong hầu hết các trường hợp, tránh sử dụng từ khóa new
trong JavaScript.
6. Function Hoisting
– Ở bài viết Khái niệm Hoisting trong JavaScript, chúng ta đã biết được là: Hoisting là hành vi mặc định của JavaScript để di chuyển một khai báo đến đầu phạm vi hiện tại.
– Hoisting áp dụng cho cả các khai báo biến và khai báo hàm.
– Do đó, các hàm JavaScript có thể được gọi trước khi chúng được khai báo:
Ví dụ:
[code language=”javascript”]myFunction(5);function myFunction(y) {
return y * y;
}[/code]
Các hàm được định nghĩa bằng cách sử dụng biểu thức (expression) thì không được hoist.
7. Cách một hàm tự gọi chính nó
– Biểu thức hàm (Function expression) có thể tự gọi chính nó (self-invoking) một cách tự động mà không cần lời gọi hàm.
– Các function expressions sẽ thực thi tự động nếu biểu thức được theo sau bởi ().
– Khai báo hàm (function declaration) không thể tự gọi chính nó.
– Bạn cần thêm dấu ngoặc đơn quanh hàm để biểu thị rằng đó là một biểu thức hàm (function expression):
Ví dụ:
[code language=”javascript”](function () {var x = "Hello!"; // I will invoke myself.
})();[/code] Try it »
– Hàm trên thực sự là một hàm tự gọi ẩn danh (anonymous self-invoking function – hàm mà không có tên).
8. Function có thể được sử dụng làm giá trị
– Các hàm JavaScript có thể được sử dụng làm giá trị cho một biến:
Ví dụ:
[code language=”javascript”]function myFunction(a, b) {return a * b;
}
var x = myFunction(4, 3); // 12[/code]
– Các hàm JavaScript cũng có thể được sử dụng trong các biểu thức (expressions):
Ví dụ:
[code language=”javascript”]function myFunction(a, b) {return a * b;
}
var x = myFunction(4, 3) * 2; // 24[/code]
9. Function là một Object
– Khi lấy type của hàm JavaScript bằng toán tử typeof sẽ trả về kết quả là function.
– Tuy nhiên, các hàm JavaScript có thể được thể hiện như là các đối tượng. Các hàm JavaScript có cả thuộc tính (properties) và phương thức (methods).
– Thuộc tính arguments.length trả về số đối số nhận được khi hàm được gọi:
Ví dụ:
[code language=”javascript”]function myFunction(a, b) {return arguments.length; // return 2
}[/code] Try it »
– Phương thức toString() trả về hàm dưới dạng một chuỗi.
Ví dụ:
[code language=”javascript”]function myFunction(a, b) {return a * b;
}
var txt = myFunction.toString();[/code] Try it »
– Một function được định nghĩa như một property của đối tượng, thì nó được gọi là method của object.
– Một function được thiết kế để tạo mới một đối tượng, thì nó được gọi là object constructor.
[…] Ở bài viết Tổng quan về hàm trong JavaScript, chúng ta đã biết rằng hàm có thể có các tham số […]