Ở bài viết trước, mình đã giới thiệu tổng quát về các hệ điều hành di động nổi tiếng hiện nay. Trong bài viết này, mình sẽ đưa ra một số hướng phát triển ứng dụng, cùng với những ưu nhược điểm của nó.
Hiện nay, có 3 hướng chính để thiết kế app, đó là: Web App, Native App và Hybrid App. Mỗi hướng sẽ cần những kĩ năng riêng, có những ưu nhược điểm riêng, sẽ được nói rõ hơn bên dưới.
Thiết kế Web App
Hướng Mobile Web thường được áp dụng khi các bạn đã có sẵn một website đang hoạt động. Ta sẽ tạo thêm 1 trang web riêng cho mobile, sử dụng HTML, CSS, một số framework hỗ trợ mobile và responsive (Bootstrap, jQuery Mobile, Materialize). Người dùng sẽ trang web dành cho mobile để dùng ứng dụng.
Các xử lý khác liên quan đến backend như database sẽ được thực hiện phía trên server. Với một số công nghệ như AngularJS, một trang web có thể giống y hệt một ứng dụng di động thật sự. Mình có viết 1 game đơn giản trên nền web, bạn hãy thử vào bằng di động, nó cũng khá giống 1 ứng dụng thật sự.
Ưu điểm
- Chỉ cần có kiến thức về web là viết được
- Viết một lần, chạy được trên mọi hệ điều hành
- Người dùng không cần phải cài app, có thể vào thẳng trang web
- Không cần phải thông qua App Store, tiết kiệm tiền
- Dễ nâng cấp (Chỉ việc nâng cấp web là xong)
Nhược điểm
- Với một số máy đời cũ, Web App sẽ bị bể giao diện, hiển thị sai, hoặc javascript không chạy.
- Performance chậm
- Không thể tận dụng được các tính năng của di động: Push notification, chụp hình, nghiêng máy, định vị GPS…
Kĩ năng cần có
- Kiến thức HTML, CSS, Javascript cơ bản.
- Kiến thức về một số framework responsive/mobile như: jQuery Mobile, Bootstrap, …
- Một số framework javascript để viết Single Page Application: AngularJS, EmberJS, …
Thiết kế Native App
Viết Native App nghĩa là lập trình viên sẽ sử dụng IDE, SDK mà nhà sản xuất cung cấp để lập trình ra một ứng dụng, build ứng dụng đó thành file cài và gửi lên App Store để kiểm duyệt. Người dùng sẽ phải tìm ứng dụng trên App Store, tải về máy và chạy.
Đây là hướng phát triển được áp dụng nhiều nhất, điển hình là game Flappy Bird của Nguyễn Hà Đông. Với những ứng dụng game, xử lý ảnh, cần tính toán nhiều, Native App là lựa chọn duy nhất.
Với những hệ thống lớn, cần đồng bộ, ta vẫn phải viết phần back-end trên server. Server sẽ đưa ra một số API. Native app lấy dữ liệu về máy, truyền dữ liệu lên server thông qua các API này.
Ưu điểm
- Tận dụng được toàn bộ những tính năng của device: Chụp ảnh, nghiêng máy, rung, GPS, notification.
- Có thể chạy được offline.
- Performance rất nhanh, vì code native sẽ được chạy trực tiếp.
- Là lựa chọn duy nhất cho các ứng dụng game, xử lý hình ảnh hay video …
Khuyết điểm
- Cần cài đặt nặng nề (Eclipse, XCode, Android SDK, …), khó tiếp cận.
- Với mỗi hệ điều hành, ta phải viết một ứng dụng riêng. Khó đảm bảo sự đồng bộ giữa các ứng dụng (1 button trên Android sẽ khác 1 button trên iOS, pop cũng khác).
- Cần phải submit app lên App Store, mỗi lần update phải thông báo người dùng.
- Code mệt và lâu hơn so với Mobile Web.
Kĩ năng cần có
- Ngôn ngữ lập trình: Java cho Android, Objective-C hoặc Swift cho iOS, C# cho Windows Phone.
- Kiến thức chuyên sâu về ứng dụng: View, Action, Adapter trong Android …
- Cách xây dựng Web Serivce, Restful API, cách gọi API từ device, …
Thiết kế Hybrid App
Hybrid App kết hợp những ưu điểm của Mobile Web và Native App. Ta xây dựng một ứng dụng bằng HTML, CSS, Javascript, chạy trên WebView của mobile. Tuy nhiên, Hybrid App vẫn có thể tận dụng những tính năng của device: chụp hình, GPS, rung, ….
Hybrid App sẽ được viết dựa trên một cross-platform framework: Cordova, Phonegap, Titanium, …. Ta sẽ gọi những chức năng của mobile thông qua API mà framework này cung cấp, dưới dạng Javascript. Bạn chỉ cần viết một lần, những framework này sẽ tự động dịch ứng dụng này ra các file cài đặt cho Android, iOS và Windows Phone.
Một số ứng dụng không quá nặng về xử lý, cần tận dụng chức năng của device sẽ chọn hướng phát triển này. Đây là một game dạng hybrid app mình viết bằng ionicPlatform.
Ưu điểm
- Chỉ cần biết HTML, CSS, JS (Thế nên mình mới khuyên các bạn nên học Javascript).
- Viết một lần, chạy được trên nhiều hệ điều hành
- Tận dụng được các chức năng của device.
Khuyết điểm
- Không ổn định, khó debug. Framework sẽ dịch code của bạn thành code native, việc sửa lỗi ứng dụng khá khó vì bạn không biết code sẽ được dịch ra như thế nào.
- Performance chậm.
- Cần cài đặt nhiều thứ (Titanium, Cordova đều bắt phải cài đặt SDK này nọ thì mới build ứng dụng được).
Kiến thức cần biết
- HTML, CSS, Javscript cơ bản.
- Cách dùng một số framework CSS, Javascript: jQuery Mobile, Ionic Framework, AngularJS, Bootstrap, …
- Kiến thức về các cross-platform framework: Titanium, Cordova, Phonegap.
- Cách xây dựng Web Serivce, Restful API, cách gọi API từ device, … (Hybrid app cũng sẽ kết nối với server thông qua API như Native App).