Menu
×

Được chứng nhận

Ghi lại kiến ​​thức của bạn

Đăng nhập Đăng ký

Tạo Tài khoản Example.com.vn miễn phí để cải thiện trải nghiệm học tập của bạn

Người tìm đường và việc học của tôi

Theo dõi tiến độ học tập của bạn tại Example.com.vn và thu thập phần thưởng

Nâng cấp

Trở thành người dùng PLUS và mở khóa các tính năng mạnh mẽ (không có quảng cáo, lưu trữ, hỗ trợ, ..)

Bắt đầu từ đâu

Bạn không chắc chắn muốn bắt đầu từ đâu? Đi theo con đường được hướng dẫn của chúng tôi

Trình chỉnh sửa mã (Dùng thử)

Với trình chỉnh sửa mã trực tuyến của chúng tôi, bạn có thể chỉnh sửa mã và xem kết quả trong trình duyệt của mình

Video

Tìm hiểu những điều cơ bản về HTML qua video hướng dẫn thú vị và hấp dẫn

Mẫu

Chúng tôi đã tạo một loạt mẫu trang web đáp ứng mà bạn có thể sử dụng - miễn phí!

Web hosting

Lưu trữ trang web của riêng bạn và chia sẻ nó với mọi người với Example.com.vn Spaces

Tạo một máy chủ

Tạo máy chủ của riêng bạn bằng Python, PHP, React.js, Node.js, Java, C#, v.v.

Làm thế nào để

Bộ sưu tập lớn các đoạn mã cho HTML, CSS và JavaScript

Khung CSS

Xây dựng các trang web nhanh và phản hồi bằng cách sử dụng khung W3.CSS miễn phí của chúng tôi

Thống kê trình duyệt

Đọc xu hướng dài hạn của việc sử dụng trình duyệt

Tốc độ gõ

Kiểm tra tốc độ đánh máy của bạn

Đào tạo AWS

Tìm hiểu dịch vụ web của Amazon

Bộ chọn màu

Sử dụng công cụ chọn màu của chúng tôi để tìm các màu RGB, HEX và HSL khác nhau. Bánh xe màu hình tròn thể hiện sự chuyển màu trong quang phổ

Trò chơi mã

Trò chơi mã hóa W3Schools! Giúp linh miêu thu thập nón thông Logo Lynx

Đặt mục tiêu

Nhận hành trình học tập được cá nhân hóa dựa trên các kỹ năng và mục tiêu hiện tại của bạn

Bản tin

Tham gia bản tin của chúng tôi và có quyền truy cập vào nội dung độc quyền mỗi tháng

Việc làm

Thuê những tài năng công nghệ hàng đầu. Hợp lý hóa quy trình tuyển dụng của bạn để có đội ngũ phù hợp hoàn hảo

Lớp học

Hãy liên hệ để sử dụng Example.com.vn Plus và các chứng chỉ với tư cách là một tổ chức giáo dục

×
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP CÁCH W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS AN NINH MẠNG DỮ LIỆU KHOA HỌC

Hướng dẫn Vue

Vue HOME Vue Giới thiệu Vue Chỉ thị Vue v-bind Vue v-if Vue v-show Vue v-for Vue Sự kiện Vue v-on Vue Methods Vue Event Modifier Vue Forms Vue v-model Vue CSS Binding Vue Tính toán Thuộc tính Vue Watchers Vue Mẫu

Mở rộng quy mô

Vue Tại sao, Cách thức và Thiết lập Trang SFC đầu tiên của Vue Thành phần Vue Đạo cụ Vue Vue v-for Thành phần Vue $emit() Vue Thuộc tính dự phòng Vue Kiểu dáng có phạm vi Vue Thành phần cục bộ Vue Slots Vue v-slot Vue Scoped Slots Vue Thành phần động Vue Teleport Vue Yêu cầu HTTP Mẫu Vue Tham chiếu Vòng đời Vue Móc nối Vue Cung cấp/Tiêm Vue Định tuyến Vue Đầu vào biểu mẫu Vue Vue Animations Vue Animations với v-for Vue Build Vue Composition API

Tham khảo Vue

Thuộc tính tích hợp của Vue Các thành phần tích hợp của Vue Các phần tử tích hợp Vue Ví dụ thành phần Vue Chỉ thị Vue Tùy chọn phiên bản Vue Móc vòng đời Vue

Vue Ví dụ

Ví dụ về Vue Bài tập Vue Vue Quiz Vue Server Chứng chỉ Vue

Phương thức Vue $emit()

Với phương thức $emit() tích hợp trong Vue, chúng ta có thể tạo một sự kiện tùy chỉnh trong thành phần con có thể được ghi lại trong thành phần cha.

Props được sử dụng để gửi dữ liệu từ phần tử cha đến thành phần con và $emit() được sử dụng để thực hiện điều ngược lại: truyền thông tin từ thành phần con đến thành phần cha.

Mục đích của những việc chúng ta sẽ làm tiếp theo là kết thúc bằng trạng thái 'yêu thích' của một mặt hàng thực phẩm sẽ được thay đổi trong App.vue gốc thay vì trong thành phần con FoodItem.vue nơi sự thay đổi hiện đang diễn ra.

Lý do thay đổi trạng thái yêu thích trong App.vue thay vì trong FoodItem.vue là vì App.vue là nơi lưu trữ trạng thái yêu thích ngay từ đầu nên cần phải cập nhật. Trong một dự án lớn hơn, dữ liệu có thể đến từ cơ sở dữ liệu mà chúng tôi kết nối trong App.vue và chúng tôi muốn một thay đổi xảy ra từ thành phần này để tạo ra thay đổi trong cơ sở dữ liệu, vì vậy chúng tôi cần liên lạc lại với thành phần gốc từ thành phần con .

Phát ra một sự kiện tùy chỉnh

Cần phải gửi thông tin từ thành phần đến thành phần mẹ và chúng tôi sử dụng phương thức tích hợp sẵn $emit() để thực hiện điều đó.

Chúng ta đã có phương thức toggleFavorite bên trong thành phần FoodItem.vue chạy khi nút chuyển đổi được nhấp vào. Bây giờ, hãy xóa dòng hiện có và thêm một dòng để phát ra sự kiện tùy chỉnh 'toggle-favorite' của chúng tôi:

FoodItem.vue :

 methods: {
  toggleFavorite() {
    this.foodIsFavorite = !this.foodIsFavorite;
    this.$emit('toggle-Favorite');
  }
}

Chúng ta có thể chọn tên cho sự kiện tùy chỉnh của mình, nhưng việc sử dụng kebab-case cho các sự kiện phát ra là điều bình thường.


Nhận một sự kiện phát ra

Sự kiện phát ra tùy chỉnh 'toggle-favorite' hiện được phát ra từ thành phần FoodItem.vue , nhưng chúng ta cần lắng nghe sự kiện trong App.vue cha và gọi một phương thức thực hiện điều gì đó để chúng ta có thể thấy sự kiện đó đã xảy ra.

Chúng ta lắng nghe sự kiện bằng cách viết tắt @ thay vì v-on: trong App.vue nơi thành phần được tạo:

Ví dụ

Nghe sự kiện 'toggle-favorite' trong App.vue :

 <food-item
  v-for="x in foods"
  :key="x.name"
  :food-name="x.name"
  :food-desc="x.desc"
  :is-favorite="x.favorite"
  @toggle-favorite="receiveEmit"
/>

Khi sự kiện tùy chỉnh 'toggle-favorite' xảy ra, chúng ta cần tạo phương thức receiveEmit trong App.vue để có thể thấy sự kiện đó đã xảy ra:

 methods: {
  receiveEmit() {
    alert('Hello World!');
  }
}
Chạy ví dụ »

Thay đổi trạng thái 'yêu thích' của mặt hàng thực phẩm trong phần gốc

Bây giờ chúng tôi có một sự kiện thông báo cho App.vue khi nút 'Yêu thích' được nhấp vào từ thành phần con.

Chúng tôi muốn thay đổi thuộc tính 'yêu thích' trong mảng 'thực phẩm' trong App.vue cho đúng mặt hàng thực phẩm khi nhấp vào nút 'Yêu thích'. Để làm điều đó, chúng tôi gửi tên mặt hàng thực phẩm từ FoodItem.vue đến App.vue vì đó là tên duy nhất cho mỗi mặt hàng thực phẩm:

FoodItem.vue :

 methods: {
  toggleFavorite() {
    this.$emit('toggle-favorite' , this.foodName );
  }
}

Bây giờ chúng ta có thể nhận tên mặt hàng thực phẩm trong App.vue làm đối số cho phương thức được gọi khi sự kiện 'toggle-favorite' xảy ra, như sau:

Ví dụ

App.vue :

 methods: {
  receiveEmit( foodId ) {  
    alert( 'You clicked: ' + foodId );
  }
}
Chạy ví dụ »

Bây giờ chúng ta đã biết mặt hàng thực phẩm nào được nhấp vào, chúng ta có thể cập nhật trạng thái 'yêu thích' cho mặt hàng thực phẩm chính xác bên trong mảng 'thực phẩm':

App.vue :

 methods: {
  receiveEmit(foodId) {
    const foundFood = this.foods.find(
      food => food.name === foodId
    );
    foundFood.favorite = !foundFood.favorite;
  }
}

Trong đoạn mã trên, phương thức mảng 'find' đi qua mảng 'foods' và tìm kiếm một đối tượng có thuộc tính name bằng với mặt hàng thực phẩm mà chúng ta đã nhấp vào và trả về đối tượng đó là 'foundFood'. Sau đó, chúng ta có thể đặt 'foundFood.health' đối lập với giá trị trước đó để nó chuyển đổi giữa truefalse .

Tìm hiểu thêm về phương thức mảng JavaScript “find” tại đây .

Tìm hiểu thêm về các hàm mũi tên của JavaScript tại đây .

Thực phẩm chính xác bên trong mảng 'thực phẩm' hiện được cập nhật trạng thái 'yêu thích'. Việc duy nhất còn lại là cập nhật hình ảnh món ăn yêu thích.

Bởi vì các thành phần mặt hàng thực phẩm đã được tạo với trạng thái 'favorite' từ mảng 'foods' và được gửi dưới dạng prop 'is-favorite' từ App.vue , nên chúng ta chỉ cần tham khảo prop 'isFavorite' này trong FoodItem.vue từ v-show trong đó phần tử <img> dùng để cập nhật hình ảnh:

 <img src="/img_quality.svg" v-show=" isFavorite ">

Chúng ta cũng có thể xóa thuộc tính dữ liệu 'foodIsFavorite' trong FoodItem.vue vì nó không còn được sử dụng nữa.

Ví dụ

Trong mã ví dụ cuối cùng này, trạng thái yêu thích của các mặt hàng thực phẩm có thể được chuyển đổi theo cách tương tự như trước, nhưng bây giờ trạng thái yêu thích đã được sửa đổi ở đúng vị trí, bên trong App.vue .

Chạy ví dụ »

Tùy chọn 'phát ra'

Tương tự như cách chúng ta khai báo props bên trong thành phần FoodItem.vue , chúng ta cũng có thể ghi lại những gì thành phần đó phát ra bằng cách sử dụng tùy chọn Vue 'emits'.

Đạo cụ phải được khai báo trong thành phần, trong khi các lần phát ra chỉ được khuyến nghị ghi lại.

Đây là cách chúng ta có thể ghi lại sự phát ra của mình trong thành phần FoodItem.vue :

 <script>
export default {  
  props: ['foodName','foodDesc','isFavorite'],
  emits: ['toggle-favorite'],
  methods: {
    toggleFavorite() {
      this.$emit('toggle-favorite', this.foodName);
    }
  }
};
</script>

Thành phần này trở nên dễ dàng hơn cho người khác sử dụng khi các lần phát ra được ghi lại.


Bài tập Vue

Kiểm tra bản thân bằng các bài tập

Bài tập:

Đạo cụ được sử dụng để gửi dữ liệu 
từ phần tử cha đến thành phần con, 
Và được sử dụng để truyền thông tin 
từ thành phần con đến thành phần cha.

Bắt đầu bài tập



×

Liên hệ bán hàng

Nếu bạn muốn sử dụng dịch vụ của Example.com.vn với tư cách là một tổ chức giáo dục, nhóm hoặc doanh nghiệp, hãy gửi email cho chúng tôi:
[email được bảo vệ]

Báo cáo lỗi

Nếu bạn muốn báo cáo lỗi hoặc nếu bạn muốn đưa ra đề xuất, hãy gửi email cho chúng tôi:
[email được bảo vệ]

Example.com.vn được tối ưu hóa cho việc học tập và đào tạo. Các ví dụ có thể được đơn giản hóa để cải thiện khả năng đọc và học. Các hướng dẫn, tài liệu tham khảo và ví dụ liên tục được xem xét để tránh sai sót, nhưng chúng tôi không thể đảm bảo tính chính xác hoàn toàn của mọi nội dung. Khi sử dụng W3Schools, bạn đồng ý đã đọc và chấp nhận các điều khoản sử dụng , chính sách cookie và quyền riêng tư của chúng tôi.

Bản quyền 1999-2024 của Refsnes Data. Đã đăng ký Bản quyền. Example.com.vn được cung cấp bởi W3.CSS .