jQuery / Javascript для определения ОС без плагина? - PullRequest
36 голосов
/ 12 августа 2011

Я ищу способ определить ОС для страницы загрузок, используя jQuery или Javascript, чтобы рекомендовать определенные файлы для Mac против Windows. Я надеялся сделать это, не добавляя другой плагин на мою страницу.

Ответы [ 7 ]

56 голосов
/ 12 августа 2011

Попробуйте:

var os = navigator.platform;

Затем обработайте переменную os соответствующим образом для вашего результата.

Вы также можете перебирать каждый объект объекта navigatorпоможет вам ближе познакомиться с объектами:

<script type="text/javascript">
for(var i in navigator){
    console.log(i+"="+navigator[i]+'<br>');
}
</script>
31 голосов
/ 12 августа 2011

Простой JavaScript может быть всем, что вам нужно.

var OSName="Unknown OS";
if (navigator.appVersion.indexOf("Win")!=-1) OSName="Windows";
if (navigator.appVersion.indexOf("Mac")!=-1) OSName="MacOS";
if (navigator.appVersion.indexOf("X11")!=-1) OSName="UNIX";
if (navigator.appVersion.indexOf("Linux")!=-1) OSName="Linux";

document.write('Your OS: '+OSName);

Как Ник предложил, вы также можете использовать navigator.platform.

13 голосов
/ 01 августа 2012

Насколько я знаю, platform является менее поддельным свойством навигатора Object. Вы можете использовать это для получения логических значений.

var isMac = navigator.platform.toUpperCase().indexOf('MAC')!==-1;
var isWindows = navigator.platform.toUpperCase().indexOf('WIN')!==-1;
var isLinux = navigator.platform.toUpperCase().indexOf('LINUX')!==-1;

Если вам нужно различить Mac между старым PowerPc и новым Intel.

var isMacPpc=navigator.platform==="MacPPC";
var isMacIntel=navigator.platform==="MacIntel";

https://developer.mozilla.org/en/DOM/window.navigator.platform

6 голосов
/ 12 августа 2011

Попробуйте:

alert(navigator.appVersion);

Это должно дать вам строку, которую вы можете проанализировать для ОС.

5 голосов
/ 06 января 2014
<script>

osName = 'Unknown';

function nav(x, y, z) {
    z = z || y;
    if (navigator[x] && navigator[x].indexOf(y) !== -1) {
        osName = z;
    }
}

/*   navigator     value     download  */
nav( "appVersion", "X11",    "UNIX"    );
nav( "appVersion", "Mac",    "MacOS"   );
nav( "appVersion", "Linux"             );
nav( "userAgent",  "Linux"             );
nav( "platform",   "Linux"             );
nav( "appVersion", "Win",    "Windows" );
nav( "userAgent",  "Windows"           );
nav( "platform",   "Win",    "Windows" );
nav( "oscpu",      "Windows"           );

document.getElementById("download"+osName).className = "knownOS";

</script>

Убедитесь, что нужную ссылку для скачивания легко найти, но не скрывайте ссылки на другие ОС. Люди могут все еще хотеть их.

<style>

#downloadUNIX, #downloadMacOS, #downloadLinux, #downloadWindows {
    color:#6D94F2;
    line-height:35px;
    margin:24px 0 24px 0;
    padding:10px;
}
.knownOS {
    background-color:#F7ECAD !important;
    border:2px solid #E8913A;
    color:#133CC4 !important;
    font-weight:bold;
}

</style>

И немного HTML

<ul>
    <li><a id="downloadUNIX"    href="unix Link Here"   >Download Napster-9000 for UNIX</a></li>
    <li><a id="downloadWindows" href="windows Link Here">Download Napster-9000 for Windows</a></li>
    <li><a id="downloadMacOS"   href="mac os link here" >Download Napster-9000 for OS X</a></li>
    <li><a id="downloadLinux"   href="linux Link Here"  >Download Napster-9000 for Linux</a></li>
</ul>

Теперь пользователь может отключить или заблокировать JavaScript, если он хочет. Ссылки будут все еще там, в отличие от написания ссылок с Javascript, для работы которого требуется javascript.

Вот скрипка

http://jsfiddle.net/7fmJb/

0 голосов
/ 22 декабря 2018

Я думаю, что это может помочь:

navigator.appVersion

Попробуйте утешить его в своем файле JS.Например:

console.log(navigator.appVersion);

Вы получите большую часть информации об ОС.

0 голосов
/ 17 сентября 2018

Вы можете использовать эту функцию внутри функции готовности документа.Добавьте код внутри функции для вашего события.

function checkOperatingSystem()
{
    var  userAgent = navigator.userAgent || navigator.vendor || window.opera;

    //Check mobile device is Android
    if (/android/i.test(userAgent)) {
        //Add your Code here
    }

    //Check mobile device is IOS
    if (/iPad|iPhone|iPod/.test(userAgent) && !window.MSStream) {
        //Add your Code here
    }

    //Check device os is Windows (For Laptop and PC)
    if (navigator.appVersion.indexOf("Win")!=-1)
    {
        //Add your Code here
    }

    //Check device os is MAC (For Laptop and PC)
    if (navigator.appVersion.indexOf("Mac")!=-1)
    {
        //Add your Code here
    }  
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...