JavaScript的BOM相關內容

来源:https://www.cnblogs.com/leilei99/archive/2020/07/23/13367190.html
-Advertisement-
Play Games

BOM(瀏覽器對象模型)簡介、window對象、location對象、history對象、navigator對象、screen對象、document對象 ...


BOM(瀏覽器對象模型)

BOM(瀏覽器對象模型)簡介

BOM是Browser Object Model的簡寫,即是瀏覽器對象模型。

BOM由一系列對象組成,是訪問、控制、修改客戶端瀏覽器的屬性的方法。其中代表瀏覽器視窗的window對象是BOM的頂層對象,其他對象都是該對象的子對象。

BOM沒有統一的標準(每種客戶端都可以自定標準)

  • JavaScript語法的標準化組織是ECMA

  • DOM的標準化組織是W3C

  • BOM沒有缺乏標準,BOM最初是Netscape瀏覽器標準的一部分

 

window對象

window,中文是“視窗”的意思。window對象代表一個瀏覽器或一個框架。window對象會在<body><frameset>每次出現時被自動創建。

JavaScript中任何一個全局函數或變數都是window的屬性

window對象除了是BOM中所有對象的父對象外,還包含一些常用屬性、方法。

window.方法和window.屬性就可以訪問了。

存在相容性的屬性、方法:狀態欄屬性status

過時的屬性、方法:打開新視窗的open()、框架集合對象frames[]、與視窗操作有關的屬性、方法:name、pageXOffset、pageYOffset、moveTo()、moveBy()等

常用的屬性和方法:

alert():顯示帶有一段信息和一個確認按鈕的警告框

window.alert("qqq");

alert("111"); //不加window也可以調用

confirm():顯示帶有一段信息以及確認按鈕和取消按鈕的對話框

if(confirm("您是否要關閉視窗?")){

console.log("是");

}else{

console.log("否");

}

close():關閉瀏覽器視窗

print():列印當前視窗的內容

scrollBy():按照指定的像素值來滾動內容

scrollTo():把內容滾動到指定的坐標

clearInterval():取消由setInterval()設置的timeout

clearTimeout():取消由setTimeout()設置的timeout

setInterval():按照指定的周期(以毫秒計算)來調用函數或計算表達式

setTimeout():在指定的毫秒數後調用函數或計算表達式

 

 setInterval()與setTimeout()的相同與不同:

相同:語法一樣,都是一個周期執行一個函數

不同:setTimeout()只會執行一次,setInterval()按照周期去迴圈執行

setTimeout()與setInterval() 相比,編碼要少一些,但做複雜控制時, setTimeout() 的返回值沒有及時清除會經常造成不可預料的意外。在使用setTimeout()或setInterval() 的時候,一定要註意的他們的返回值的問題,否則會出現各種異常。

 

location對象

location對象是屬於window對象的子對象

location對象是由JavaScript runtime engine自動創建的,包含有關當前url信息

常用屬性:

hash:設置或返回從#號開始的url

host:設置或返回主機或當前的url的埠號

hostname:設置或返回當前的URL主機名

href:設置或返回完整的URL

pastname:設置或返回當前URL的路徑部分

port:設置或返回當前URL的埠號

protocol:設置或返回當前URL的協議

search:設置或返回從問號(?)開始的URL(查詢部分)

常用方法:

assign():載入新的文檔

reload():重新載入當前文檔

replace():用新的文檔替代當前文檔

 

利用自己的伺服器測試了一下,就是有點不太好

 

 

 

history對象

history對象是屬於window對象的子對象

後退、前進

history對象是由JavaScript runtime engine自動創建的,由一系列的url組成。這些url是用戶在一個瀏覽器視窗內已訪問的url

方法:

back():載入history列表中的上(前)一個URL

forward():載入history列表中的下一個URL

go():載入history列表中的某一個具體頁面

navigator對象

判斷瀏覽器版本、瀏覽器相容性(版本問題)

navigator對象是由JavaScript runtime engine自動創建的,包含有關客戶機瀏覽器的信息。

常用屬性:

appCodeName:返回瀏覽器的代碼號

appName:返回瀏覽器的名稱

appVersion:返回瀏覽器的平臺和版本信息

cookieEnabled:返回指明瀏覽器中是否啟用cookie的布爾值

platform:返回運行瀏覽器的操作系統平臺

userAgent:返回由客戶機發送伺服器的user-agent頭部的值

回話機制:所有的網頁都能訪問到回話裡面的數據

screen對象

screen 對象是屬於Window對象的子對象。

screen對象是由 JavaScript runtime engine 自動創建的,含有關客戶機顯示屏幕的信息。

常用屬性:

availHeight:返回顯示屏幕的高度(除window任務欄之外)

availWidth:返回顯示屏幕的寬度(除window任務欄之外)

bufferDepth:設置或返回在off-screen bitmap buffer中調色板的比特深度

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

deviceXDPI:返回顯示屏幕的每英寸水平點數

deviceYDPI:返回顯示屏幕的每英寸垂直點數

fontSmoothingEnabled:返回用戶是否在顯示控制面板中啟用了字體平滑

height:返回顯示屏幕的高度

width:返回顯示屏幕的寬度

logicalXDPI:返回顯示屏幕每英寸的水平方向的常規點數

logicalYDPI:返回顯示屏幕每英寸的垂直方向的常規點數

pixelDepth:返回顯示屏幕的顏色解析度(比特每像素)

updateInterval:設置或返回屏幕的刷新率

document對象

document對象是window對象的子對象。

document對象的獨特之處是它是唯一一個既屬於BOM 又屬於DOM的對象。

從BOM角度看,document對象由一系列集合構成,這些集合可以訪問文檔的各個部分,並提供頁面自身的信息。再有,由於BOM沒有可以指導實現的標準,所以每個瀏覽器實現的document對象都稍有不同,這一節的重點是最常用的功能。

常用屬性:

cookie:設置或返回與當前文檔有關的所有cookie

domain:返回當前文檔的功能變數名稱

referrer:返回載入當前文檔的文檔的URL

title:返回當前文檔的標題

URL:返回當前文檔的URL

常用方法:

getElementById():返回對擁有指定 id 的第一對象的引用

getElementsByName():返回對擁有指定 名稱 的對象集合

getElementsByTagName():返回對擁有指定 標簽名稱 的對象集合

write():向文檔寫HTML表達式或JavaScript代碼

writeIn():等同於write()方法,不同的是每個表達式之後加一個換行符

 

代碼:

<!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8">     <meta name="viewport" content="width=device-width, initial-scale=1.0">     <title>BOM的使用</title>     <style>         .box{             border: 1px solid #e2e2e2;             float: left;             width: 150px;             height: 50px;             text-align: center;             line-height: 50px;             cursor: pointer;             margin-left: 80px;         }         #scoll{             width: 80px;             height: 200vh;             background-color: palevioletred;             font-size: 20px;         }         #flexd{             position: fixed;             bottom: 50px;             right: 50px;             background-color: purple;             width: 80px;             height: 80px;             cursor: pointer;         }     </style> </head> <body>     <div class="box">打開視窗</div>     <div class="box">關閉視窗</div>     <div class="box">計時</div>     <div class="box">關閉計數器</div>     <div id="scoll">         山有木兮木有枝,心悅君兮君不知。     </div>     <div id="flexd"></div>     <hr>     <div class="box">返回上一層</div>     <div class="box">前進</div>     <div class="box">前進到第三個</div>          <script>         let open = document.getElementsByClassName("box"),             tscoll = document.getElementById("flexd"),             newwindow = null,             timer = null;         open[0].onclick = function (){             newwindow = window.open("two.html","scrollbars=yes, width=400, height=200");             newwindow.focus(); //focus的作用是使新視窗保持在最前面         }         open[1].onclick = function (){             newwindow.close();         }         tscoll.onclick = function (){             // window.scrollTo(0,0);  //返回到頂部,x軸,y軸             window.scrollBy(100,100);   //按照指定的像素值來滾動內容         }         let i = 0;         // open[2].onclick = function(){         //     timer = window.setInterval(function (){         //         open[2].innerHTML = "計時:" + i;         //         i++;         //     },1000)         // }         // open[3].onclick = function(){         //     window.clearInterval(timer);         // }         open[2].onmousemove = function(){             timer = window.setTimeout(function (){                 open[2].innerHTML = i;                 console.log("11");                 i++;             },1000)         }                  open[3].onclick = function(){             window.clearTimeout(timer);         }
        document.write('<p>返回從井號 (#) 開始的 URL(錨):'+window.location.hash+'</p>');         document.write('<p>返回主機名和當前 URL 的埠號:'+window.location.host+'</p>');         document.write('<p>返回當前 URL 的主機名:'+window.location.hostname+'</p>');         document.write('<p>返回完整的 URL:'+window.location.href+'</p>');         document.write('<p>返回當前 URL 的路徑部分:'+window.location.pathname+'</p>');         document.write('<p>返回當前 URL 的埠號:'+window.location.port+'</p>');         document.write('<p>返回當前 URL 的協議:'+window.location.protocol+'</p>');         document.write('<p>返回從問號 (?) 開始的 URL(查詢部分):'+window.location.search+'</p>');         document.write('<hr>');

        open[4].onclick = function(){             window.history.back();         }         open[5].onclick = function(){             window.history.forward();         }         open[6].onclick = function(){             window.history.go(3);         }         document.write('瀏覽器的代碼名:' + window.navigator.appCodeName + '<br/>');         document.write('瀏覽器的名稱:' + window.navigator.appName + '<br/>');         document.write('瀏覽器的平臺和版本信息:' + window.navigator.appVersion + '<br/>');         document.write('瀏覽器中是否啟用了cookie:' + window.navigator.cookieEnabled + '<br/>');         document.write('運行瀏覽器的操作系統:' + window.navigator.platform + '<br/>');         document.write('user-agent頭部信息:' + window.navigator.userAgent + '<br/>');         document.write('<hr>');
        document.write('<p>屏幕的高度 (除 Windows 任務欄之外):'+window.screen.availHeight+'</p>');         document.write('<p>屏幕的寬度 (除 Windows 任務欄之外):'+window.screen.availWidth+'</p>');         document.write('<p>調色板的比特深度:'+window.screen.colorDepth+'</p>');         document.write('<p>屏幕的高度:'+window.screen.height+'</p>');         document.write('<p>屏幕的寬度:'+window.screen.width+'</p>');         document.write('<hr>');
        document.write('<p>當前文檔有關的所有 cookie:' + document.cookie +'</p>');         document.write('<p>當前文檔的功能變數名稱:' + document.domain +'</p>');         document.write('<p>載入當前文檔的文檔的 URL:' + document.referrer +'</p>');         document.write('<p>當前文檔的標題:' + document.title +'</p>');         document.write('<p>當前文檔的 URL:' + document.URL +'</p>');
    </script> </body> </html>

 

效果: 

 

 

 

 

document對象


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

-Advertisement-
Play Games
更多相關文章
  • 功能點: 1.更新彈窗UI 2.強更與非強更且別控制 3.屏蔽物理返回鍵(因為強更的時候點擊返回鍵,彈窗會消失) 4.點擊彈窗外透明區域時,彈窗不消失 ...
  • 1.盒子模型主要定義四個區域:內容(content)、內邊距(padding)、邊框(border)、外邊距(margin) 2.border,設置元素的邊框,屬性(邊框三要素):寬度、樣式、顏色,這也是通常border屬性值的書寫順序(非嚴格要求) 單獨書寫:border-width(寬度,預設3 ...
  • 快速反饋對於任何 UI 的實現都是至關重要的。研究表明,100ms 是界面讓用戶感到即時的最大延遲。儘管如此,移動網路仍然受到一個巨大的反饋問題的困擾:觸摸任何元素後,延遲 300 毫秒。這種延遲是許多用戶認為基於 HTML 的 Web 應用程式“卡頓”的最重要原因之一。在本文中,本文將帶你瞭解移動... ...
  • 一個網站建立以後,如果不註意安全方面的問題,很容易被人攻擊,下麵就討論一下幾種漏洞情況和防止攻擊的辦法。 一、SQL註入 所謂SQL註入,就是通過把SQL命令插入到Web表單提交或輸入功能變數名稱或頁面請求的查詢字元串,最終達到欺騙伺服器執行惡意的SQL命令。具體來說,它是利用現有應用程式,將(惡意)的SQ ...
  • 通過 javascript 偽協議, HTML5 dialog 元素實現的分屏書簽程式 ...
  • 俗話說,出來江湖混的,持善良之心,懷正義之氣,總有志同道合者共相為謀。而HTML也有這麼幾個大哥們er、小兄dei、小寶貝兒。他們一起乾大事,為服務好普羅大眾貢獻自己一份力量,接下來讓我們一起走進他們吧。 ...
  • 什麼是 DOM? 如果我們把這個 HTML 載入到瀏覽器中,瀏覽器創建這些節點,用來顯示網頁。所以這個HTML映射到一系列DOM節點,然後我們可以使用JavaScript進行操作。例如: let item = document.getElementByTagName('h1')[0] item.te ...
  • 微信端返回按鈕 WeixinJSBridge.call('closeWindow'); $("#close").click(function(){ setTimeout(function(){WeixinJSBridge.call('closeWindow');},1000); }) ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...