瀏覽器根對象window之screen

来源:https://www.cnblogs.com/ndos/archive/2018/01/08/8245164.html
-Advertisement-
Play Games

1. screen 1.1 availHeight/Width screen.availWidth返回瀏覽器視窗可占用的水平寬度(單位:像素)。 screen.availHeight返回瀏覽器視窗在屏幕上可占用的垂直空間,即最大高度。 1.2 availLeft/Top availTop:瀏覽器視窗 ...


1. screen

1.1 availHeight/Width

screen.availWidth返回瀏覽器視窗可占用的水平寬度(單位:像素)。

screen.availHeight返回瀏覽器視窗在屏幕上可占用的垂直空間,即最大高度。

1.2 availLeft/Top

availTop:瀏覽器視窗在屏幕上的可占用空間上邊距離屏幕上邊界的像素值。

availLeft:返回瀏覽器可用空間左邊距離屏幕(系統桌面)左邊界的距離。

大多數情況下,該屬性返回 0。

如果你在有兩個屏幕的電腦上使用該屬性,在右側屏幕計算該屬性值時,返回左側屏幕的寬度(單位:像素),也即左側屏幕左邊界的 X 坐標。

在 Windows 中,該屬性值取決於哪個屏幕被設為主屏幕,返回相對於主屏幕左邊界的 X 坐標。就是說,即使主屏幕不是左側的屏幕,它的左邊界的 X 坐標也是返回 0。如果副屏幕在主屏幕的左側,則它擁有負的 X 坐標。

[1] [2] - 左屏幕 availLeft 返回 0,右側的屏幕返回左側屏幕的寬度

[2] [1] - 左側屏幕 availLeft 返回該屏幕的 -width,右側屏幕返回 0

1.3 colorDepth

colorDepth 屬性返回目標設備或緩衝器上的調色板的比特深度。

if (screen.colorDepth<=8)
    //為8位屏幕的簡單的藍色背景色
    document.body.style.background="#0000FF"
else
    //為現代屏幕的華麗的藍色背景色
    document.body.style.background="#87CEFA"

相同的顏色在不同設備中,渲染的視覺色彩不同,可用該屬性來進行調色。

1.4 pixelDepth

返回屏幕的位深度/色彩深度(bit depth)。根據CSSOM( CSS對象模型 )視圖,為相容起見,該值總為24。

// 如果沒有足夠的位深度/色彩深度(bit depth),就選擇一個更純的顏色
if ( window.screen.pixelDepth > 8 ) {
  document.style.color = "#FAEBD7";
} else {
  document.style.color = "#FFFFFF";
}

1.5 width/height

height返回屏幕的高度(單位:像素)。註意,該屬性返回的高度值並不是全部對瀏覽器視窗可用。小工具(Widgets),如任務欄或其他特殊的程式視窗,可能會減少瀏覽器視窗和其他應用程式能夠利用的空間。

當返回屏幕高度時,IE 會考慮縮放設置。只有當縮放比例為 100% 時,IE 才會返回真實的屏幕高度。

width返回屏幕的寬度。註意,該屬性返回的寬度值不一定就是瀏覽器視窗可使用的寬度。當有其他小工具占據了屏幕空間時,瀏覽器有時不能占用小工具(如任務欄)占據的空間。window.screen.width 和 window.screen.availWidth 兩者不同。相關屬性 window.screen.height。

在返回該值時,IE 會考慮縮放設置。只有在縮放比例為 100% 時,IE 才返回真實的屏幕寬度。

1.6 orientation[H5]

type

表示當前屏幕是橫屏(landscape-primary)還是豎屏(portrait-primary)。只讀屬性。orientation.type還有兩個值landscape-secondary和portrait –secondary。值portrait-secondary將橫屏模式旋轉180°

var orientation = screen.orientation || screen.mozOrientation || screen.msOrientation;

if (orientation.type === "landscape-primary") {
  console.log("橫屏.");
} else if (orientation.type === "landscape-secondary") {
  console.log("橫屏(另外一個方向。註:橫屏有兩個方向)");
} else if (orientation.type === "portrait-secondary" || orientation.type === "portrait-primary") {
  console.log("豎屏");
}
angle

角度為0等同於自然方向,大部分智能手機的自然方向是portrait-primary;

90°等同於landscape-primary;

180°等同portrait-secondary;

270°等同landscape-secondary。

不同的設備,angle代表不同的關鍵字。為了獲取方向值,瀏覽器需要運行在全屏模式下。

lock/unlock

通過screen.orientation屬性的lock()方法可以調整屏幕方向,其預設值是any,這允許設備根據其物理方向來應用任何方向。值”natural”將在設備的自然方向上顯示網站,因設備而異。智能手機通常使用橫屏,平板則使用豎屏。

screen.orientation.lock("natural");

上面的示例中,為設備設置自然方向。

當然,Screen Orientation API也允許你定義一個獨立的方向,其有四個值可以選擇,這已經包含了移動設備所有可能的方向。這四個值分別是: “portrait-primary”, “portrait-secondary”, “landscape-primary”和 “landscape-secondary”。

change事件

通過change事件改變屏幕方向也是可以的,只需要調用addEventListener()為orientation屬性註冊change事件並添加一個函數(作為事件處理程式)。

screen.orientation.addEventListener("change", function(e) {
  alert(screen.orientation.type + " " + screen.orientation.angle);
}, false);

每一次屏幕方向的改變都會觸發彈框,顯示當前的方向關鍵字和角度。

當使用Screen Orientation API時,還需要記住一件事:由於要Fullscreen API一起使用才能起作用,所以不應該使用它來設計網站之類的。對於需要全屏模式的瀏覽器游戲或其他應用程式,它能有更好的效果。

詳細使用方式可參見下列網站:HTML5 Screen Orientation API實現橫屏或豎屏


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • dict是一種用於保存鍵值對的抽象數據結構,在redis中使用非常廣泛,比如資料庫、哈希結構的底層。 ...
  • 1,被測試的應用程式必須是Developer簽名的應用程式或者是運行在模擬器裡面的應用程式。 2,在被測試的應用程式開發的過程中需要處理UI控制項的可訪問性。使用IB的開發工程師需要在XIB中加入一個Accessibility屬性設置。該屬性直接控制在執行UI Automation時UI控制項的可操作性 ...
  • Twitter曾經舉行了自己四年以來的第一場開發者大會。而這場名為“Flight”的大會,也是以後它的年度慣例。 這次大會的主題也完全圍繞開發者進行。大會的焦點是一個名叫Fabric的新SDK,裡面包括三個開發者工具包:面向Twitter本身的 Twitter Kit、面向Twitter廣告網路的M ...
  • 在處理完框架記憶體泄漏的問題後,發現業務代碼有一個地方的記憶體沒釋放,原因很也簡單:block和self互相強引用了,接下來。。。。。。 ...
  • Runtime 前言 從字面意思看,就是運行時。但是這個運行時究竟什麼意思?可以把它理解成:不是在編譯期也不是在鏈接期,而是在運行時。那究竟在運行期間做了什麼呢?按照蘋果官方的說法,就是把一些決策(方法的調用,類的添加等)推遲,推遲到運行期間。只要有可能,程式就可以動態的完成任務,而不是我們在編譯期 ...
  • 1,Instruments iOS自帶的自動化測試工具。 2,TuneupJs 最早的iOS自動化測試工具 https://github.com/alexvollmer/tuneup_js 3,ynm3k 在UI控制項遍歷方面有比較大的優勢 https://github.com/douban/ynm3 ...
  • 第一次寫博客,想著就從頭來吧,希望幫助到需要的人。 HTML超文本標記語言(Hyper text markup language),“超文本”就是指頁面內可以包含圖片、鏈接,甚至音樂、程式等非文字元素;標記語言指語言具有可讀性,什麼是可讀性呢?比如在html裡面的table指表格、p(pragrap ...
  • 這個世界需要一個特定的惡人,可以供人們指名道姓,千夫所指:“全都怪你”。 ——村上春樹《當我談跑步時我談些什麼》 本文為讀 lodash 源碼的第六篇,後續文章會更新到這個倉庫中,歡迎 star: "pocket lodash" gitbook也會同步倉庫的更新,gitbook地址: "pocket ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...