Khi xây dựng ứng dụng web dựa trên nội dung, bạn cần xem xét những trình duyệt mà độc giả đang sử dụng. Một số người dùng có thể sử dụng trình duyệt cũ không hỗ trợ các tính năng mới nhất, trong khi một số người khác có thể đang sử dụng trình duyệt mới hơn có nhiều tính năng hơn. Tất cả người dùng đều có thể truy cập ứng dụng của bạn, bất kể lựa chọn trình duyệt của họ là gì.
Sử dụng tính năng nâng cao tăng dần hoặc bắt đầu bằng các tính năng cơ bản nhất mà tất cả trình duyệt đều hỗ trợ, sau đó thêm các tính năng bổ sung cho các trình duyệt mới hơn. Phát hiện tính năng là một chiến lược khác nhằm tiếp cận người dùng bằng trình duyệt cũ hoặc mới. Với tính năng phát hiện tính năng, bạn có thể xác định tính năng nào mà trình duyệt của người dùng hỗ trợ, sau đó bạn tải mã thích hợp. Ứng dụng của bạn phải sử dụng các tính năng mới nhất mà trình duyệt của người dùng có thể hỗ trợ.
Có một số điểm cần cân nhắc khi nhắm mục tiêu cả trình duyệt cũ và hiện đại. Trước tiên, bạn có thể cần phải sử dụng mã riêng cho các trình duyệt khác nhau. Điều này có thể khiến mã của bạn phức tạp và khó duy trì hơn. Có thể bạn sẽ không dùng được các tính năng mới nhất trong mọi trình duyệt. Điều này có thể hạn chế chức năng của ứng dụng.
Tuỳ thuộc vào ứng dụng, các trình duyệt cũ có thể vẫn cần hỗ trợ vì lý do pháp lý hoặc trường hợp sử dụng trong kinh doanh. Nếu phần lớn người dùng sử dụng phần cứng cũ và không thể cập nhật, thì có thể cần đến các polyfill. Đoạn mã polyfill cung cấp các tính năng hiện đại cho các trình duyệt web cũ và có thể cho phép bạn sử dụng các công nghệ web và API hiện đại nhất trong khi vẫn đảm bảo khả năng tương thích với các trình duyệt cũ.
Có nhiều công cụ hữu ích để kiểm tra xem công nghệ hoặc API nào được sử dụng:
- Project Baseline: là một nỗ lực nhằm cải thiện trải nghiệm của nhà phát triển bằng cách cung cấp những gì hoạt động tốt trong các trình duyệt được hỗ trợ, đồng thời được Google và các hệ thống thường dùng khác hỗ trợ.
- Caniuse: là tài nguyên để tra cứu các API Web và xem trạng thái hỗ trợ trên tất cả các trình duyệt được theo dõi.