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

使用CSS媒體查詢和JavaScript判斷瀏覽器設備類型的好方法

  發(fā)布時間:2014-04-03 09:23:00   作者:佚名   我要評論
這篇文章主要介紹了使用巧妙使用CSS媒體查詢(Media Queries)和JavaScript判斷瀏覽器設備類型的好方法,需要的朋友可以參考下
有無數的理由要求我們在任何時候都應該知道用戶是使用的什么設備瀏覽我們的網站——寬屏,普通屏,平板,手機?知道這些特征,我們web應用的CSS和JavaScript才能同步做相應的操作。在給Mozilla Developer Networks改版設計的過程中,我發(fā)現使用CSS媒體查詢(media queries)雖然非常的有效,但有時,JavaScript卻不能及時知道用戶瀏覽設備的狀態(tài)。瀏覽網站的用戶使用的是桌面電腦,還是平板,還是手機?這對于CSS來說很容易,但CSS卻無法將這些信息告訴JavaScript。我發(fā)明了一種基于CSS媒體查詢和z-index屬性的方法,能告訴JavaScript用戶當前使用的是什么屏幕,這樣我能調整JavaScript的動作來響應這種屏幕尺寸。

CSS代碼

首先最重要的還是CSS媒體查詢代碼。這里只是示例,我們創(chuàng)建了三個媒體查詢規(guī)則(但不包括缺省的“all”),它能控制四種屏幕情況:桌面(這是缺省狀態(tài),不需要媒體查詢規(guī)則),“小屏幕”,平板,手機。針對每一種屏幕,我們給它一種不同的z-index值,這個值我們可以用JavaScript檢測到。我們把這個元素定位到屏幕外,這樣它就不會顯示出來;記住,它的作用就是存放z-index值,我們要用javaScript獲取這個值。


復制代碼
代碼如下:

/* 缺省屏幕 */
.state-indicator {
position: absolute;
top: -999em;
left: -999em;
z-index: 1;
}
/* 小屏幕 */
@media all and (max-width: 1200px) {
.state-indicator {
z-index: 2;
}
}
/* 平板 */
@media all and (max-width: 1024px) {
.state-indicator {
z-index: 3;
}
}
/* 手機 */
@media all and (max-width: 768px) {
.state-indicator {
z-index: 4;
}
}

每種z-index都在告訴我們的JavaScript當前的用戶使用的是什么規(guī)格的屏幕。我們并不像知道用戶究竟使用的是什么設備,因為你可以將瀏覽器寬度拉的很窄,但我們需要就是可視寬度,這樣我們可以調整應用的布局。

JavaScript代碼

也許你認為可以在DomContentLoaded時知道屏幕的大小,但我們需要實時知道屏幕的大小(因為用戶會調整瀏覽器窗口的大小),我們需要有個方法獲取當前窗口的屬性:

復制代碼
代碼如下:

// 創(chuàng)建狀態(tài)指示元素
var indicator = document.createElement('div');
indicator.className = 'state-indicator';
document.body.appendChild(indicator);
// 獲取設備類別的方法
function getDeviceState() {
return parseInt(window.getComputedStyle(indicator).getPropertyValue('z-index'), 10);
}

使用這個方法,你就能檢測出頁面布局/js飾件中那些需要顯示,那些需要隱藏。

復制代碼
代碼如下:

if(getDeviceState() < 3) { // 如果是桌面電腦后小屏幕電腦
// 顯示js飾件....
}

有人也許會認為這些數字太容易搞錯,讓代碼很難維護。其實我們可以用一個對象來處理這種事情:

復制代碼
代碼如下:

function getDeviceState() {
var index = parseInt(window.getComputedStyle(indicator).getPropertyValue('z-index'), 10);
var states = {
2: 'small-desktop',
3: 'tablet',
4: 'phone'
};
return states[index] || 'desktop';
}

這樣,你就一個寫出更具可讀性的邏輯判斷:

復制代碼
代碼如下:

if(getDeviceState() == 'tablet') {
// Do whatever
}

也許使用CSS的偽元素的content屬性是個更好的方法:

復制代碼
代碼如下:

.state-indicator {
position: absolute;
top: -999em;
left: -999em;
}
.state-indicator:before { content: 'desktop'; }
/* 小屏幕桌面 */
@media all and (max-width: 1200px) {
.state-indicator:before { content: 'small-desktop'; }
}
/* 平板 */
@media all and (max-width: 1024px) {
.state-indicator:before { content: 'tablet'; }
}
/* 手機 */

用下面的JavaScript方法獲取關鍵的內容:

復制代碼
代碼如下:

var state = window.getComputedStyle(
document.querySelector('.state-indicator'), ':before'
).getPropertyValue('content')

如何組織這些代碼全看你自己了。如果你有一個全局對象,例如window.config或window.app等,你可以把這些方法放到里面。我傾向于模塊化這些功能,你可以把它做成jQuery插件或JavaScript工具包。不管你如何實現,它們都是你可以信賴的、簡單易用的檢測用戶設備的好方法。

更上一層樓

我們知道屏幕尺寸會發(fā)生變化——用戶手工調整瀏覽器大型或手機用戶調整了手機方向,所以,當這些事件發(fā)生時,我們需要讓系統(tǒng)告訴我們。下面這段簡單的代碼估計是你需要的:

復制代碼
代碼如下:

var lastDeviceState = getDeviceState();
window.addEventListener('resize', debounce(function() {
var state = getDeviceState();
if(state != lastDeviceState) {
// 保持當前的狀態(tài)
lastDeviceState = state;
// 宣告狀態(tài)變化,通過自定義的DOM事件或JS 消息發(fā)布/訂閱模式,
// 我喜歡后者,所有就假設使用了一個這樣的工具庫
publish('/device-state/change', [state]);
}
}, 20));
// 用法
subscribe('/device-state/change', function(state) {
if(state == 3) { // or "tablet", if you used the object
}
});

注意,這里我使用了debounce方法來執(zhí)行resize事件發(fā)生時的動作——這對于性能來說非常重要。是使用自定義DOM事件還是使用發(fā)布/訂閱模式,你自由選擇,因為都很簡單。

我覺得這種方法非常的好。有人可能會指出使用matchMedia也可以有相同效果,但問題是你需要在CSS里和JavaScript里都使用媒體查詢,而有些媒體查詢語句可能會很復雜,甚至會成為你的噩夢,不如使用簡單的z-index。也有人會說可以使用 window.innerWidth來判斷,但這樣JS里獲取的屬性和CSS里的媒體查詢就需要相互轉換了,同樣也會成為你的惡魔。我的方法的好處就在于你可以用它判斷其他類型的媒體查詢屬性,例如檢查手機是橫向(landscape)還是豎向(portrait)。

不管怎樣,你可以試一下,告訴我你的感覺!

相關文章

  • 前端CSS Grid 布局示例詳解

    CSS Grid 是一種二維布局系統(tǒng),可以同時控制行和列,相比 Flex(一維布局),更適合用在整體頁面布局或復雜模塊結構中,這篇文章主要介紹了前端CSS Grid 布局詳解,需要的朋
    2025-04-16
  • CSS Padding 和 Margin 區(qū)別全解析

    CSS 中的 padding 和 margin 是兩個非常基礎且重要的屬性,它們用于控制元素周圍的空白區(qū)域,本文將詳細介紹 padding 和 margin 的概念、區(qū)別以及如何在實際項目中使用它們
    2025-04-07
  • CSS will-change 屬性示例詳解

    will-change 是一個 CSS 屬性,用于告訴瀏覽器某個元素在未來可能會發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧
    2025-04-07
  • CSS去除a標簽的下劃線的幾種方法

    本文給大家分享在 CSS 中,去除a標簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細,感興趣的朋友一起看看吧
    2025-04-07
  • 前端高級CSS用法示例詳解

    在前端開發(fā)中,CSS(層疊樣式表)不僅是用來控制網頁的外觀和布局,更是實現復雜交互和動態(tài)效果的關鍵技術之一,隨著前端技術的不斷發(fā)展,CSS的用法也日益豐富和高級,本文將
    2025-04-07
  • css中的 vertical-align與line-height作用詳解

    文章詳細介紹了CSS中的`vertical-align`和`line-height`屬性,包括它們的作用、適用元素、屬性值、常見使用場景、常見問題及解決方案,感興趣的朋友跟隨小編一起看看吧
    2025-03-26
  • 淺析CSS 中z - index屬性的作用及在什么情況下會失效

    z-index屬性用于控制元素的堆疊順序,值越大,元素越顯示在上層,它需要元素具有定位屬性(如relative、absolute、fixed或sticky),本文給大家介紹CSS 中z - index屬性的作用
    2025-03-21
  • CSS @media print 使用詳解

    文章詳細介紹了CSS中的打印媒體查詢@mediaprint包括基本語法、常見使用場景和代碼示例,如隱藏非必要元素、調整字體和顏色、處理鏈接的URL顯示、分頁控制、調整邊距和背景等
    2025-03-18
  • CSS模擬 html 的 title 屬性(鼠標懸浮顯示提示文字效果)

    本文介紹了如何使用CSS模擬HTML的title屬性,通過鼠標懸浮顯示提示文字效果,通過設置`.tipBox`和`.tipBox.tipContent`的樣式,實現了提示內容的隱藏和顯示,感興趣的朋友一起
    2025-03-10
  • 前端 CSS 動態(tài)設置樣式::class、:style 等技巧(推薦)

    本文介紹了Vue.js中動態(tài)綁定類名和內聯(lián)樣式的兩種方法:對象語法和數組語法,通過對象語法,可以根據條件動態(tài)切換類名或樣式;通過數組語法,可以同時綁定多個類名或樣式,此外
    2025-02-26

最新評論