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 » Khai Báo Biến Mảng Trong Vba
-
Mảng (Array) Trong VBA - VietTuts
-
VBA ARRAY TRONG EXCEL - HƯỚNG DẪN ĐẦY ĐỦ
-
Kỹ Thuật Khai Báo Mảng động Trong VBA Với Cú Pháp ReDim
-
Hướng Dẫn Về Mảng Trong VBA Excel: Các Kiểu động, đa Chiều
-
Excel VBA: Mảng Trong VBA - Viblo
-
3 Ví Dụ ứng Dụng Mảng Trong VBA Excel - YouTube
-
Array_Mảng | Tự Học VBA
-
Khai Báo Biến Mảng Trong VBA - HelpEx
-
Bài 3: Khai Báo Biến Trong VBA | Cùng Học Excel
-
Xử Lý Mảng Trong VBA Thông Qua Ví Dụ đơn Giản - Freetuts
-
Các Câu Hỏi Về Mảng Trong VBA (Array) | Giải Pháp Excel
-
LÀM VIỆC VỚI MẢNG TRONG VBA | Bugatino's Note
-
Mảng (array) Trong VBA Excel - Tài Liệu Text - 123doc