欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Js 獲取、判斷瀏覽器版本信息的簡(jiǎn)單方法

 更新時(shí)間:2016年08月08日 11:02:18   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇Js 獲取、判斷瀏覽器版本信息的簡(jiǎn)單方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧

Navigator 對(duì)象包含有關(guān)瀏覽器的信息:

•appCodeName -- 瀏覽器代碼名的字符串表示

•appName -- 官方瀏覽器名的字符串表示

•appVersion -- 瀏覽器版本信息的字符串表示

•cookieEnabled -- 如果啟用cookie返回true,否則返回false

•javaEnabled -- 如果啟用java返回true,否則返回false

•platform -- 瀏覽器所在計(jì)算機(jī)平臺(tái)的字符串表示

•plugins -- 安裝在瀏覽器中的插件數(shù)組

•taintEnabled -- 如果啟用了數(shù)據(jù)污點(diǎn)返回true,否則返回false

•userAgent -- 用戶代理頭的字符串表示

navigator中最重要的是userAgent屬性,返回包含瀏覽器版本等信息的字符串;

cookieEnabled也很重要,使用它可以判斷用戶瀏覽器是否開啟cookie。

javaScript判斷瀏覽器類型一般有兩種辦法,一種是根據(jù)各種瀏覽器獨(dú)有的屬性來(lái)分辨,另一種是通過分析瀏覽器的userAgent屬性來(lái)判斷(版本只能通過分析userAgent獲得);

只有在瀏覽器類型 和 瀏覽器版本都判斷出后,才能處理兼容性問題。

1、通過userAgent中的特征來(lái)判斷瀏覽器類型及版本(常用、保險(xiǎn)做法)

function getBrowserInfo() {
  var Sys = {};
  var ua = navigator.userAgent.toLowerCase();
  var s; (s = ua.match(/msie ([\d.]+)/)) ? Sys.ie = s[1] :
  (s = ua.match(/firefox\/([\d.]+)/)) ? Sys.firefox = s[1] :
  (s = ua.match(/chrome\/([\d.]+)/)) ? Sys.chrome = s[1] :
  (s = ua.match(/opera.([\d.]+)/)) ? Sys.opera = s[1] :
  (s = ua.match(/version\/([\d.]+).*safari/)) ? Sys.safari = s[1] : 0;

  if(Sys.ie) {
    return 'IE: ' + Sys.ie;
  }
  if(Sys.firefox) {
    return 'Firefox: ' + Sys.firefox;
  }
  if(Sys.chrome) {
    return 'Chrome: ' + Sys.chrome;
  }
  if(Sys.opera) {
    return 'Opera: ' + Sys.opera;
  }
  if(Sys.safari) {
    return 'Safari: ' + Sys.safari;
  }
} 
var browser = getBrowserInfo() ;
var verinfo = (browser+"").replace(/[^0-9.]/ig, "");   // 版本號(hào)

注意:一些瀏覽器的userAgent屬性值中Chrome、Safari皆有,是因?yàn)镃hrome的userAgent還包含了Safari的特征,因此這可能是Chrome可運(yùn)行Safari瀏覽器應(yīng)用的基礎(chǔ)的原因。

2、通過各瀏覽器獨(dú)有特性來(lái)分辨瀏覽器(需注意:這些特征可能會(huì)隨瀏覽器版本而變化,或是其他瀏覽器也就可能跟著加入該特性,從而導(dǎo)致判斷失?。?/p>

IE:只有IE支持創(chuàng)建ActiveX控件,所以ActiveXObject函數(shù)是其他瀏覽器沒有的。只需判斷window對(duì)象存在 ActiveXObject函數(shù),就明確判斷出當(dāng)前瀏覽器是IE。

Firefox:FF中的DOM元素都有一個(gè)getBoxObjectFor函數(shù),用來(lái)獲取該DOM元素的位置和大小。這是Firefox獨(dú)有的,判斷它即可分辨當(dāng)前瀏覽器是Firefox。(IE對(duì)應(yīng)的中是 getBoundingClientRect函數(shù))

Opera:Opera提供了專門的瀏覽器標(biāo)志-- window.opera屬性。

Safari:openDatabase函數(shù)是其他瀏覽器沒有的,可做為判斷Safari的標(biāo)志。

Chrome:和FF一樣都一個(gè)MessageEvent函數(shù),但Chrome并沒有FF的getBoxObjectFor 函數(shù),根據(jù)這兩個(gè)條件可判斷Chrome瀏覽器。

var Sys = {};
var ua = navigator.userAgent.toLowerCase();
if(window.ActiveXObject) {
  Sys.ie = ua.match(/msie ([\d.]+)/)[1]
}else if(document.getBoxObjectFor) {
  Sys.firefox = ua.match(/firefox\/([\d.]+)/)[1]
}else if(window.MessageEvent && !document.getBoxObjectFor) {
  Sys.chrome = ua.match(/chrome\/([\d.]+)/)[1]
}else if(window.opera) {
  Sys.opera = ua.match(/opera.([\d.]+)/)[1]
}else if(window.openDatabase) {
  Sys.safari = ua.match(/version\/([\d.]+)/)[1];
}

水平有限,文中錯(cuò)誤不妥在所難免,歡迎批評(píng)指正建議評(píng)論。文章將不定期修改完善斧正。謝謝!

以上這篇Js 獲取、判斷瀏覽器版本信息的簡(jiǎn)單方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 小程序?qū)崿F(xiàn)頁(yè)面跳轉(zhuǎn)與數(shù)據(jù)傳遞方案

    小程序?qū)崿F(xiàn)頁(yè)面跳轉(zhuǎn)與數(shù)據(jù)傳遞方案

    在開發(fā)過程中經(jīng)常會(huì)遇到在微信小程序的頁(yè)面跳轉(zhuǎn)以及數(shù)據(jù)傳遞的知識(shí)點(diǎn),所以下面這篇文章主要給大家介紹了關(guān)于小程序?qū)崿F(xiàn)頁(yè)面跳轉(zhuǎn)與數(shù)據(jù)傳遞的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • javascript 動(dòng)態(tài)腳本添加的簡(jiǎn)單方法

    javascript 動(dòng)態(tài)腳本添加的簡(jiǎn)單方法

    下面小編就為大家?guī)?lái)一篇javascript 動(dòng)態(tài)腳本添加的簡(jiǎn)單方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2016-10-10
  • Bootstrap每天必學(xué)之js插件

    Bootstrap每天必學(xué)之js插件

    Bootstrap每天必學(xué)之js插件,Bootstrap 自帶 12 種 jQuery 插件,擴(kuò)展了功能,可以給站點(diǎn)添加更多的互動(dòng),感興趣的小伙伴們可以參考一下
    2015-11-11
  • javascript編寫實(shí)用的省市選擇器

    javascript編寫實(shí)用的省市選擇器

    這篇文章主要介紹了javascript編寫實(shí)用的省市選擇器的方法及示例分享,非常不錯(cuò),推薦給有相同需求的小伙伴們。
    2015-02-02
  • TopList標(biāo)簽和JavaScript結(jié)合兩例

    TopList標(biāo)簽和JavaScript結(jié)合兩例

    TopList標(biāo)簽和JavaScript結(jié)合兩例...
    2007-08-08
  • 基于JavaScript實(shí)現(xiàn)單選框下拉菜單添加文件效果

    基于JavaScript實(shí)現(xiàn)單選框下拉菜單添加文件效果

    這篇文章主要介紹了基于JavaScript實(shí)現(xiàn)單選框下拉菜單添加文件效果的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-06-06
  • js如何獲取網(wǎng)頁(yè)所有圖片

    js如何獲取網(wǎng)頁(yè)所有圖片

    這篇文章主要為大家詳細(xì)介紹了js如何獲取網(wǎng)頁(yè)所有圖片,js獲取網(wǎng)頁(yè)所有圖片的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • js實(shí)現(xiàn)文件上傳功能 后臺(tái)使用MultipartFile

    js實(shí)現(xiàn)文件上傳功能 后臺(tái)使用MultipartFile

    這篇文章主要為大家詳細(xì)介紹了純js實(shí)現(xiàn)最簡(jiǎn)單的文件上傳功能,后臺(tái)使用MultipartFile,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • JS模仿MSN右下角彈出提示框代碼

    JS模仿MSN右下角彈出提示框代碼

    JS模仿MSN右下角彈出提示框代碼,需要的朋友可以參考下。
    2010-09-09
  • JS 跳轉(zhuǎn)頁(yè)面延遲2種方法

    JS 跳轉(zhuǎn)頁(yè)面延遲2種方法

    js跳轉(zhuǎn)頁(yè)面想必大家不會(huì)很陌生吧,在瀏覽頁(yè)面的時(shí)候經(jīng)常會(huì)碰到這種現(xiàn)象存在如果可以延遲的話是不是會(huì)更委婉一點(diǎn)呢,接下來(lái)為大家介紹下如何實(shí)現(xiàn),感興趣的朋友可以參考下哈
    2013-03-03

最新評(píng)論