Могу ли я вывести предупреждение, если браузер пользователя не поддерживается? - PullRequest
0 голосов
/ 10 октября 2018

Я работаю над реагирующим приложением, и клиенты хотят, чтобы оно показывало специальное сообщение, если старый браузер пользователя не поддерживает (например, IE 9) .

Так долго я пытался обнаружить некоторые «популярные» старые браузеры, используя пакет react-device-detect.

src / index.js

import { browserName, browserVersion } from "react-device-detect";

const render = Component => {
  if (browserName === "IE" && browserVersion < 10) {
    ReactDOM.render(<UnsupportedBrowser />, document.getElementById("root"));
  } else {
    ReactDOM.render(
      <AppContainer>
        <Component store={store} history={history} />
      </AppContainer>,
      document.getElementById("root")
    );
  }
};

и добавление условных комментариев:

public / index.html

<!--[if lte IE 9]>
  Please upgrade your browser
<![endif]-->

Но у меня есть подозрение, что есть лучшие способы, которые я не смог найти в Интернете.

Ответы [ 2 ]

0 голосов
/ 05 ноября 2018

Я нашел много JS-скриптов для определения имени и версии браузера пользователя, поэтому мне пришлось смешать их, чтобы получить именно то, что я хочу

public / index.html

<script type="text/javascript">
    function get_browser() {
      var ua = navigator.userAgent, tem, M = ua.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || [];
      if (/trident/i.test(M[1])) {
        tem = /\brv[ :]+(\d+)/g.exec(ua) || [];
        return { name: 'IE', version: (tem[1] || '') };
      }
      if (M[1] === 'Chrome') {
        tem = ua.match(/\bOPR\/(\d+)/)
        if (tem != null) { return { name: 'Opera', version: tem[1] }; }
      }
      if (window.navigator.userAgent.indexOf("Edge") > -1) {
        tem = ua.match(/\Edge\/(\d+)/)
        if (tem != null) { return { name: 'Edge', version: tem[1] }; }      
      }
      M = M[2] ? [M[1], M[2]] : [navigator.appName, navigator.appVersion, '-?'];
      if ((tem = ua.match(/version\/(\d+)/i)) != null) { M.splice(1, 1, tem[1]); }
      return {
        name: M[0],
        version: +M[1]
      };
    }

    var browser = get_browser()
    var isSupported = isSupported(browser);

    function isSupported(browser) {
      var supported = false;
      if (browser.name === "Chrome" && browser.version >= 48) {
        supported = true;
      } else if ((browser.name === "MSIE" || browser.name === "IE") && browser.version >= 10) {
        supported = true;
      } else if (browser.name === "Edge") {
        supported = true;
      }
      return supported;
    }

    if (!isSupported) {
      document.write(<h1>My message</h1>)
    }
  </script>

Этот скрипт позволяет пользователям продолжить работу, если их браузер имеет chrome> = 48 или ie> = 10 или любую версию edge.В противном случае отображается специальное сообщение с просьбой обновить или изменить свой браузер.

Вы также можете настроить этот скрипт в соответствии со своими потребностями, изменив функцию isSupported ().

0 голосов
/ 10 октября 2018

У вас есть обнаружить браузер пакет на npm, который может вам помочь

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...