Trong Vue.js, việc nắm vững vòng đời của một component là vô cùng quan trọng để xây dựng ứng dụng hiệu quả. Hai phương thức thường gây nhầm lẫn nhất là mounted()
và created()
. Bài viết này sẽ phân tích sâu về sự khác biệt giữa Vue Mounted Vs Created
, giúp bạn hiểu rõ thời điểm và cách sử dụng chúng.
Sự khác biệt giữa mounted()
và created()
created()
và mounted()
đều là các hook trong vòng đời của một Vue component, nhưng chúng được gọi ở các thời điểm khác nhau, dẫn đến những khả năng và hạn chế riêng. created()
được gọi khi instance của component đã được tạo, nhưng template của nó chưa được render hoặc gắn vào DOM. Ngược lại, mounted()
được gọi sau khi template đã được render và gắn vào DOM.
Khi nào nên sử dụng created()
?
created()
là lựa chọn lý tưởng khi bạn cần thực hiện các logic không phụ thuộc vào DOM, chẳng hạn như:
- Gọi API để lấy dữ liệu ban đầu cho component.
- Khởi tạo các biến và thuộc tính của component.
- Thiết lập các subscriptions hoặc listeners cho events.
Sử dụng created()
cho các tác vụ này giúp tối ưu hiệu suất ứng dụng, vì nó được thực hiện trước khi component được render.
Khi nào nên sử dụng mounted()
?
mounted()
là thời điểm thích hợp để thực hiện các thao tác liên quan đến DOM, ví dụ như:
- Truy cập và thao tác trực tiếp với các phần tử DOM trong template.
- Tích hợp với các thư viện JavaScript của bên thứ ba yêu cầu truy cập DOM.
- Thực hiện các hiệu ứng animation hoặc transition.
So sánh vue mounted vs created
Đặc điểm | created() |
mounted() |
---|---|---|
Thời điểm gọi | Sau khi instance được tạo | Sau khi template được render và gắn vào DOM |
Truy cập DOM | Không | Có |
Thích hợp cho | Logic không phụ thuộc DOM | Thao tác DOM |
Hiệu suất | Tối ưu hơn | Thấp hơn (do cần chờ DOM sẵn sàng) |
Ví dụ thực tế
Giả sử bạn đang xây dựng một component hiển thị danh sách sản phẩm. Bạn có thể sử dụng created()
để gọi API lấy danh sách sản phẩm từ server. Sau đó, trong mounted()
, bạn có thể sử dụng thư viện carousel để tạo hiệu ứng trượt cho danh sách sản phẩm (vì lúc này DOM đã sẵn sàng).
Kết luận
Hiểu rõ sự khác biệt giữa vue mounted vs created
là chìa khóa để viết code Vue.js hiệu quả. Bằng cách chọn đúng hook cho từng tác vụ, bạn có thể tối ưu hiệu suất ứng dụng và tránh các lỗi tiềm ẩn. Hãy nhớ rằng created()
dành cho logic không phụ thuộc DOM, trong khi mounted()
dành cho thao tác DOM.
FAQ
- Tôi có thể truy cập
this.$el
trongcreated()
không? Không,this.$el
chỉ khả dụng trongmounted()
và các hook sau đó. - Tôi nên sử dụng hook nào để đăng ký event listeners? Bạn có thể đăng ký event listeners trong cả
created()
vàmounted()
, tùy thuộc vào loại event và mục đích sử dụng. mounted()
có được gọi sau mỗi lần component re-render không? Không,mounted()
chỉ được gọi một lần, khi component được mount lần đầu.- Tôi nên sử dụng hook nào để gọi API?
created()
thường được ưu tiên để gọi API vì nó không phụ thuộc vào DOM. - Sự khác biệt giữa
beforeCreate
vàcreated
là gì?beforeCreate
được gọi trước khi instance được tạo, trong khicreated
được gọi sau khi instance được tạo. - Sự khác biệt giữa
beforeMount
vàmounted
là gì?beforeMount
được gọi trước khi template được render, cònmounted
được gọi sau khi template được render và gắn vào DOM. - Tôi có thể thay đổi dữ liệu trong
mounted()
không? Có, bạn có thể thay đổi dữ liệu trongmounted()
, nhưng hãy cẩn thận vì điều này có thể gây ra re-render không cần thiết.
Mô tả các tình huống thường gặp câu hỏi
Người dùng thường gặp khó khăn trong việc quyết định nên sử dụng mounted()
hay created()
khi thực hiện các tác vụ cụ thể. Ví dụ, việc gọi API nên được thực hiện trong created()
để tránh re-render không cần thiết. Thao tác DOM chỉ nên được thực hiện trong mounted()
sau khi DOM đã sẵn sàng.
Gợi ý các câu hỏi khác, bài viết khác có trong web
- Vòng đời của một Vue component là gì?
- Các hook khác trong vòng đời của Vue component?
- Cách tối ưu hiệu suất của Vue application?
Khi cần hỗ trợ hãy liên hệ Số Điện Thoại: 0372999888, Email: [email protected] Hoặc đến địa chỉ: 236 Cầu Giấy, Hà Nội. Chúng tôi có đội ngũ chăm sóc khách hàng 24/7.