DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> Js 獲取、判斷浏覽器版本信息的簡單方法
Js 獲取、判斷浏覽器版本信息的簡單方法
編輯:關於JavaScript     

Navigator 對象包含有關浏覽器的信息:

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

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

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

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

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

•platform -- 浏覽器所在計算機平台的字符串表示

•plugins -- 安裝在浏覽器中的插件數組

•taintEnabled -- 如果啟用了數據污點返回true,否則返回false

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

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

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

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

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

1、通過userAgent中的特征來判斷浏覽器類型及版本(常用、保險做法)

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, "");   // 版本號

注意:一些浏覽器的userAgent屬性值中Chrome、Safari皆有,是因為Chrome的userAgent還包含了Safari的特征,因此這可能是Chrome可運行Safari浏覽器應用的基礎的原因。

2、通過各浏覽器獨有特性來分辨浏覽器(需注意:這些特征可能會隨浏覽器版本而變化,或是其他浏覽器也就可能跟著加入該特性,從而導致判斷失敗)

IE:只有IE支持創建ActiveX控件,所以ActiveXObject函數是其他浏覽器沒有的。只需判斷window對象存在 ActiveXObject函數,就明確判斷出當前浏覽器是IE。

Firefox:FF中的DOM元素都有一個getBoxObjectFor函數,用來獲取該DOM元素的位置和大小。這是Firefox獨有的,判斷它即可分辨當前浏覽器是Firefox。(IE對應的中是 getBoundingClientRect函數)

Opera:Opera提供了專門的浏覽器標志-- window.opera屬性。

Safari:openDatabase函數是其他浏覽器沒有的,可做為判斷Safari的標志。

Chrome:和FF一樣都一個MessageEvent函數,但Chrome並沒有FF的getBoxObjectFor 函數,根據這兩個條件可判斷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];
}

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

以上這篇Js 獲取、判斷浏覽器版本信息的簡單方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved