- vừa được xem lúc

Tôi đã dùng Service Pattern trong NuxtJS như thế nào ?

0 0 69

Người đăng: Duong Trung Hieu

Theo Viblo Asia

Giới thiệu

Trong quá trình làm VueJS NuxtJS hay thậm chí là Laravel mình cũng hay áp dụng các pattern như Service hoặc Repository. Mình cũng đã trải nghiệm qua thằng Angular, và thực sự nó support các pattern này khá tốt và theo khuôn khổ. Với VueJS hay Nuxt thì các dev sẽ phải cần có kinh nghiệm và tự dựng bằng tay Bài viết này mình mong muốn chia sẻ về cách sử dụng Service pattern trong NuxtJS mình hay làm nhằm phục vụ cho việc xử lý logic nghiệp vụ.

Lý do nên dùng?

  • Thứ nhất là mình sẽ tạch độc lập việc xử lý logic nghiệp vụ ra, code vừa đẹp vừa rõ ràng dễ maintaince.
  • Áp dụng Factory pattern được trơn tru hơn, nếu được sẽ có dịp mình viết về thằng này.
  • Vì nó độc lập... sẽ dễ tái sử dụng hơn.
  • Việc viết test đơn giản hơn.

Chung quy lại thì mình thấy khi mình maintaince các dự án có và không có các pattern như trên thì toàn gặp 1 vấn đề Thay vì tôi phải sửa lại 1 file thì tôi lại phải sửa hàng chục file

Triển khai qua ví dụ

  • Ở ví dụ này, mình sẽ lấy 1 thực thể Product làm demo và trong dự án sẽ sử dụng axios để phục vụ cho việc call API ( hoặc có thể thêm cả VueX )
  • Trước hết tại thư mục plugins mình sẽ có 1 file kiểu như sau
// plugins/services.js export default ({$axios}, inject) => { inject('getProducts', async (query) => await $axios.get('endpoint_url', { query })) inject('storeProduct', async (data) => await $axios.post('endpoint_url', data))
}
  • Trong Vue component mình có thể sử dụng nó như sau

<script> export default { name: 'ProductComponent', async mounted() { // accessing $getProducts service using this const { data } = this.$getProducts({price: '50000'}) // accessing $storeProduct service const { data } = this.$storeProduct({ name: 'awesome product' }) } }
</script>
  • Hoặc khi sử dụng với Vuex
export default { actions: { async getProducts({ commit }) { const { data } = this.$getProducts({price: '50000'}) commit('GET_PRODUCT_MUTATION', data) }, async storeProduct({ commit }, { data }) { const { data } = this.$storeProduct(data) commit('STORE_PRODUCT_MUTATION', data) }, }
}

Triển khai case thực tế

  • Ok bên trên là ví dụ về triển khai 1 services, trong trường hợp ở các case thực tế chúng ta có thể tham khảo cách triển khai như sau
// Struct folder pages
services |_AxiosConfig.js |_Index.js |_ProductService.js |_OrderService.js ...
  • Trong AxiosConfig.js sẽ tiến hành trả về 1 instance axios
import axios from 'axios'; const client = url => axios.create({ baseURL: url, withCredentials: false, headers: { Accept: 'application/json', 'Content-Type': 'application/json', }, }); export default client;
  • Trong mỗi services chúng ta sẽ tiền hành inject client vào
// plugins/services/ProductService.js
import client from './AxiosConfig'; const baseUrl = 'https://api...' export default { getProducts: async (query) => { return await client(baseUrl).get('endpoint_url', { query }) }, storeProduct: async (data) => { return await client(baseUrl).post('endpoint_url', data) }
}
  • Và giờ là lúc ta đăng ký các Service vào trong file services/Index.js
import productService from './services/ProductService' export default (inject) => { const allMethods = { ...productService(), // another service } const methods = Object.keys(allMethods) methods.forEach((method) => { inject(method, allMethods[method]) })
}

... Và sau đó là gọi trong asyncData hoặc MapGetters bla bla v....v =)))

Kết bài

  • Trên đây là các cách mình hay thực hiện, nếu các bạn có các cách khác hãy comment ở dưới bài viết để mọi người cùng nghiên cứu và chia sẻ nhé ^_^
  • LƯU Ý: Sẽ có nhiều bạn sau khi đọc xong kiểu : Ủa sao nhìn nó giống Repository Pattern vậy ta?? Ờm thực ra mình chỉ ví dụ về việc call API thôi còn thực ra mình cũng ghi rõ là giải quyết logic nghiệp vụ =)) có nghĩa là sau này khi chỉ quan tâm tới việc call API thì chúng ta có thể lồng Repository Pattern vào đó và mình muốn sẽ chia sẻ trong 1 bài viết khác giữa 2 thằng này !
  • Thanks for reading !

Bình luận

Bài viết tương tự

- vừa được xem lúc

Tổng hợp các bài hướng dẫn về Design Pattern - 23 mẫu cơ bản của GoF

Link bài viết gốc: https://gpcoder.com/4164-gioi-thieu-design-patterns/. Design Patterns là gì. Design Patterns không phải là ngôn ngữ cụ thể nào cả.

0 0 302

- vừa được xem lúc

Giới thiệu về Builder Design Pattern

Nguồn: refactoring.guru. Builder. Ý đồ.

0 0 44

- vừa được xem lúc

Một ví dụ nhỏ về Factory method

Trong bài viết trước mình đã giới thiệu tới các bạn về Abstract Factory pattern, các bạn quan tâm có thể theo dõi lại tại đây. Để tiếp tục về chủ đề design pattern trong bài viết này mình sẽ trình bày những khái niệm, ưu nhược điểm và các sử dụng của một creational design pattern khác đó là Factory

0 0 38

- vừa được xem lúc

Hướng dẫn Adapter Design Pattern

Trong bài viết này, chúng ta sẽ cùng tìm hiểu về Adapter Design Pattern qua cấu trúc, cánh triển khai, ví dụ, ưu điểm nhược điểm và ứng dụng của nó. Đây là bài viết đầu tiên của mình nên sẽ không trán

1 1 63

- vừa được xem lúc

Giới thiệu về Prototype Design Pattern

Ý đồ. Prototype là một creational design pattern cho phép bạn sao chép các object hiện có mà không làm cho code của bạn phụ thuộc vào các class của chúng.

0 0 52

- vừa được xem lúc

Học Bloc Pattern theo cách dễ hiểu nhất

Lời mở đầu. Sau khi mình đã chia sẻ xong series về Stream, RxDart thì mình tiếp tục chia sẻ về Bloc Pattern.

0 0 58