Phạm Vi Của Biến Trong VBA: Biến Cục Bộ - Toàn Cục Và Biến Module
Có thể bạn quan tâm
Trong bài này chúng ta sẽ tìm hiểu mức độ phạm vi của biến trong VBA gồm: Biến cục bộ, biến mức module và biến toàn cục.
Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.Bạn đã biết cách khai báo biến trong VBA rồi nên mình sẽ không nói về cú pháp nữa nhé, thay vào đó mình chỉ đề cập đến mức độ phạm vi hoạt động của biến, để từ đó bạn sẽ biết cách thiết lập và sử dụng cho đúng.
Trong VBA, một biến có thể được khai báo ở ba phạm vi khác nhau.
- Procedure level: Biến chỉ được sử dụng bên trong thủ thục, hàm và phương thức đó.
- Module level: Biến chỉ được sử dụng bên trong module mà nó được khai báo. Tất cả những sub, function nằm trong Module đó đều dùng được, trừ những Module bên ngoài.
- Public Module level: Mức độ này ta còn gọi là biến toàn cục, đây là biên có thể sử dụng mở mọi module trong dự án.
1. Biến cục bộ (procedure level)
Biến cục bộ hay còn gọi là biến ở mức độ thủ tục (procedure level). Biến này chỉ hoạt động trong phạm vi của thủ tục (sub), hàm (function) và thuộc tính của lớp (method). Tức là nếu bạn khai báo một biến ở một Sub thì chỉ sử dụng được trong phạm vi của sub đó mà thôi.
Bài viết này được đăng tại [free tuts .net]
Ví dụ: Chương trình bị lỗi vì biến domain ở showDomain chưa được khai báo.
Sub setDomain() Dim domain As String domain = "freetuts.net" End Sub Sub showDomain() ' Biến này bị lỗi vì chưa được khai báo MsgBox domain End SubNhư bạn thấy, ở sub setDomain mình có khai báo biến domain, nhưng ở sub showDomain không thể sử dụng được.
2. Biến ở cấp độ module (module level)
Nếu bạn muốn một biến có thể sử dụng ở mọi Sub, Function trong một module (file VBA) thì hãy khai báo nó ở phía trên cùng nhé.
Dim domain As String Sub setDomain() domain = "freetuts.net" End Sub Sub showDomain() MsgBox domain End Sub Sub callSubs() Call setDomain Call showDomain End SubĐoạn code này mình đặt trong Module1, khi chạy sub callSubs thì chương trình in ra dòng chữ "freetuts.net", điều này chứng tỏ hai sub setDomain và showDomain đã sử dụng biến domain mà không bị lỗi.
3. Biến toàn cục (public module level)
Đây được xem là mức độ cao nhất, hay còn gọi là biến toàn cục.
Trong VBA, biến toàn cục là biến mà bạn có thể sử dụng mở mọi module. Và ta sử dụng từ khóa Public để khai báo thay cho từ khóa Dim.
1. Giả sử mình tạo ra 2 module như sau:
2. Module1 mình khai báo một biến toàn cục.
Public domain As String3. Module2 mình viết hai sub có sử dụng biến này.
Sub setDomain() domain = "freetuts.net" End Sub Sub showDomain() MsgBox domain End Sub Sub callSubs() Call setDomain Call showDomain End SubKết quả khi chạy sub callSubs thì in ra dòng chữ "freetuts.net". Vậy ở Module2 đã sử dụng được biến ở Module1.
Qua bài này chắc hẳn bạn đã biết cách sử dụng biến nâng cao trong VBA rồi phải không nào? Việc phân ra cấp độ thế này sẽ giúp cho chương trình VBA hoạt động an toàn và bảo mật hơn.
Từ khóa » Các Biến Khai Báo Trong Vba
-
Hướng Dẫn Cách Khai Báo Biến Khi Viết Code Trong VBA Excel
-
Biến Và Kiểu Dữ Liệu Trong VBA - VietTuts
-
Bài 3: Khai Báo Biến Trong VBA | Cùng Học Excel
-
Cách Khai Báo Và Sử Dụng Biến Dữ Liệu Trong VBA Excel
-
Biến Và Các Kiểu Dữ Liệu Thường Dùng Trong VBA - Freetuts
-
Cách Sử Dụng Biến Trong VBA
-
HƯỚNG DẪN VỀ BIẾN SỐ, HẰNG SỐ VÀ KIỂU DỮ LIỆU TRONG ...
-
Bài 6 : Biến Và Hằng Số Trong VBA Excel
-
Bài Viết: Khai Báo Biến Và đặt Tên Biến Trong VBA | Giải Pháp Excel
-
Làm Cách Nào để Khai Báo Một Biến Toàn Cục Trong VBA?
-
Bài 5 - Cách Khai Báo Các Biến Và Hàm Trong Lập Trình VBA Excel
-
Khái Niệm Và Cách Sử Dụng Biến Số Từ Cơ Bản Tới Nâng Cao