Adaptacyjne wyświetlanie na podstawie jakości sieci

Wczytywanie strony internetowej może przebiegać inaczej w zależności od sieci. warunków. Przy szybkiej sieci wszystko zwykle działa płynnie, ale gdy jesteś w podróży z ograniczonym pakietem danych i niestabilnym połączeniem albo utkniesz z laptopem korzystającym z wolnego połączenia Wi-Fi w kawiarni, to inna historia.

Możesz sobie z tym radzić, dostosowując komponenty wyświetlane użytkownikom na podstawie jakości ich połączenia. Jest to teraz możliwe dzięki Interfejs Network Information API który umożliwia aplikacjom internetowym dostęp do informacji o sieci użytkownika.

Obsługa przeglądarek

  • 61
  • 79
  • x
  • x

Źródło

Wykorzystanie

Istnieje wiele sposobów wykorzystania tych informacji o sieci do poprawy działania użytkownika funkcje:

  • Przełączaj się między wyświetlaniem treści w wysokiej i niskiej rozdzielczości na podstawie w sieci użytkownika.
  • Zdecyduj, czy chcesz wstępnie wczytać zasoby.
  • Opóźnij przesyłanie i pobieranie plików, jeśli użytkownicy korzystają z wolnego połączenia.
  • Włącz tryb offline, jeśli jakość sieci nie jest wystarczająco dobra, aby wczytać aplikację i korzystać z tych funkcji.
  • Ostrzegaj użytkowników, że wykonywanie określonych czynności (np. oglądanie filmów) przez sieć komórkową może być płatne jego pieniądze.
  • Używaj go w statystykach, aby zbierać dane o użytkownikach jakości sieci.

Wiele aplikacji wykonuje już podobną czynność. Na przykład YouTube, Netflix i większość innych usług wideo (lub rozmów wideo) automatycznie się dostosowują do rozdzielczości w trakcie strumieniowania. Podczas ładowania Gmaila użytkownicy mogą zobaczyć link „load podstawowy HTML (dla wolnych połączeń)”.

link umożliwiający wczytanie podstawowej wersji HTML Gmaila, gdy użytkownicy korzystają z wolnego połączenia;

Jak to działa

Obiekt navigator.connection zawiera informacje o połączenia. Ich właściwości zostały objaśnione w tabeli poniżej.

Właściwość Wyjaśnienie
downlink Szacowana przepustowość w megabitach na sekundę.
effectiveType Efektywny typ połączenia z możliwymi wartościami 'slow-2g', '2g', '3g' lub '4g' (obejmuje 4 g i więcej). Jest określana na podstawie połączenia czasu w obie strony i szybkości pobierania. Na przykład szybkie łącze w połączeniu z dużym czasem oczekiwania ma niższą skuteczność obiektu z powodu czasu oczekiwania.
onchange Moduł obsługi zdarzeń uruchamiany po zmianie informacji o połączeniu.
rtt Szacowany czas oczekiwania na połączenie w obie strony (w milisekundach).
saveData Wartość logiczna określająca, czy użytkownik zażądał trybu ograniczonego użycia danych.

Po uruchomieniu w konsoli przeglądarki wygląda to tak:

Konsola Chrome DevNarzędzia z widocznymi wartościami właściwości obiektu navigator.connection

Wartości effectiveType są też dostępne w: Wskazówki dla klienta i umożliwiają przekazywanie informacji o typie połączenia przeglądarki do serwerów.

Detektor zdarzeń onchange umożliwia dynamiczne dostosowywanie się do zmian jakości sieci. Jeśli przesyłanie lub pobieranie zostało wstrzymane z powodu słabej sieci warunków, możesz polegać na tym, że detektor zdarzeń ponownie uruchomi przesyłanie, gdy wykrywa lepsze warunki sieci. Można też użyć go do powiadamiania użytkowników o tym, zmian jakości sieci. Na przykład, jeśli utracili sygnał Wi-Fi i zostali zostały przeniesione do sieci komórkowej, co może zapobiec przypadkowemu przesyłaniu danych (oraz ładowania 💸).

Użyj detektora zdarzeń onchange tak samo jak każdego innego detektora zdarzeń:

navigator.connection.addEventListener('change', doSomethingOnChange);

Podsumowanie

Potencjalne korzyści interfejsu Network Information API są duże, zwłaszcza użytkowników korzystających z powolnych sieci i aplikacji wymagających dużej przepustowości. Najlepsze może służyć jako technika stopniowego ulepszania.