BOM知識梳理

来源:http://www.cnblogs.com/unclekeith/archive/2017/06/28/7092055.html
-Advertisement-
Play Games

學過前端開發的地球人應該都瞭解,JavaScript分為三個部分:ECMAScript(JS語言本身基礎語法),DOM(文檔對象模型,應用程式編程介面),BOM(瀏覽器對象模型)。 BOM,實際上與瀏覽器有關係。因此瀏覽器廠商可以按照各自的想法隨意去擴展(基於window對象的擴展)。不過,擴展歸擴 ...


學過前端開發的地球人應該都瞭解,JavaScript分為三個部分:ECMAScript(JS語言本身基礎語法),DOM(文檔對象模型,應用程式編程介面),BOM(瀏覽器對象模型)。

BOM,實際上與瀏覽器有關係。因此瀏覽器廠商可以按照各自的想法隨意去擴展(基於window對象的擴展)。不過,擴展歸擴展,每個瀏覽器之間都遵循著一套標準。學習BOM對於理解JS這門語言仍然是很重要的,因此不能忽視。以下是我的一些總結,給出一些常用方法。並不會細說每個方法如何使用,這篇文章的主要目的,就是希望BOM在我們腦子裡形成一個簡單的框架。知道一些常用的方法,在遇到問題的時候可以追本溯源。

BOM中存在五個對象:

  1. window對象(核心對象)
  2. location對象(即是window對象的屬性,又是document對象的屬性)
  3. navigator對象
  4. history對象:至今未使用過
  5. screen對象:至今未使用過

每個對象下都存在一些屬性和方法,下麵列出幾種常見和常使用的方法,同時給出簡單的說明。

  • window對象(核心對象)的常見方法
    • 非同步:XMLHttpRequest構造函數
    • Number數據類型:Number, parseInt, parseFloat, isNaN, isFinite
    • 定時器:setTimeout, setInterval。這裡想說明一下的是,setTimeout中回調函數中的this會指向window對象,原因其實很簡單。在回調函數作為參數傳遞給了setTimout, 此時發生this的隱式賦值丟失。還有一個需要註意的是setTimeout的執行順序問題。
    • url加密:encodeURI, encodeURIComponent方法
    • url解密:decodeURI, decodeURIComponent方法
    • 視窗尺寸:(innerWidth, innerHeight) (outerWidth, outerHeight),這裡要與DOM中的client dimension和offset dimension區分開來,也就是clientWidth(Height) 和 offsetWidth(Height)
    • 視窗位置:(screenLeft, screenRight) (screenX, screenY)
    • 打開新視窗: open方法,此方法可接收三個參數
    • 系統對話框:alert, confirm, prompt方法
  • location對象
    • href屬性:獲取url地址, (也可以通過此屬性設置url地址)
    • protocal屬性:返回頁面使用的協議, (也可以通過此屬性設置protocal)
    • host屬性:返回伺服器名稱和埠號,既包括hostname + port. (也可以通過此屬性設置host)
    • hostname屬性:返回不帶埠號的伺服器名稱, (也可以通過此屬性設置hostname)
    • port屬性:返回埠號, (也可以通過此屬性設置port)
    • pathname屬性:返回url目錄或文件名, (也可以通過此屬性設置pathname)
    • hash屬性:返回url中的hash(#content), (也可以通過此屬性設置hash)
    • search屬性:query string(如?name=keith&height=180), (也可以通過此屬性設置search)
    • reload方法:頁面以最有效的方式載入。也就是說,如果頁面自上次請求以來並沒有改變過,頁面就會從瀏覽器緩存中載入。如果要強制從瀏覽器重新載入,可以傳遞一個true的布爾值。
  • navigator對象
    • userAgent:用戶代理,查詢用戶使用的瀏覽器信息。在移動端上可用於判斷用戶使用的是哪種類型的移動設備或瀏覽器

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

-Advertisement-
Play Games
更多相關文章
  • 使用Microsoft Web Platform在IIS里配置安裝一個wordpress,一切順利。 當添加一片文章時,自動生成URL類似如下: http://localhost/wordpress/index.php/2017/06/28/dc%e8%b6%85%e8%83%bd%e5%a6%b9... ...
  • 題目描述 在一個遙遠的國度,一側是風景秀美的湖泊,另一側則是漫無邊際的沙漠。該國的行政區劃十分特殊,剛好構成一個N 行M 列的矩形,如上圖所示,其中每個格子都代表一座城市,每座城市都有一個海拔高度。 為了使居民們都儘可能飲用到清澈的湖水,現在要在某些城市建造水利設施。水利設施有兩種,分別為蓄水廠和輸 ...
  • 新人初涉博客,許個願望:每天記錄一點學習筆記,不懂得,重要的,考題等等。 ...
  • 一、windows 1. 下載tomcat 2. 進入bin目錄,查看是否存在service.dat,如果沒有自行創建 3. 打開cmd,進入tomcat>bin目錄 說明:用法: service.bat install/remove [service_name] [/user username] ...
  • instanceof是Java的一個二元操作符(運算符),也是Java的保留關鍵字。它的作用是判斷其左邊對象是否為其右邊類的實例,返回的是boolean類型的數據。用它來判斷某個對象是否是某個Class類的實例。 用法: boolean result = object instanceof clas ...
  • 其實沒有完整的9天,就是連續每天花點時間,過程so frustrated,踩坑無數。。。下麵是學習過程的記錄 第1天 開始正式學習JavaEE,已完成: 1. Tomcat安裝; 2. Tomcat配置。完成了IIS占用的80埠停用,將Tomcat監聽埠改為80埠,然後修改hosts,增加解析 ...
  • 1.REST即表現層狀態傳遞(Representational [,rɛprɪzɛn'teʃnl] State Transfer,簡稱REST)。 (1)REST名詞解釋: 通俗來講就是資源在網路中以某種表現形式進行狀態轉移。分解開來: Resource:所指的不只是數據,而是數據和表現形式的組合; ...
  • 一 概述 1.什麼是UML? Unified Modeling Language,統一建模語言,用圖形化的語言展示事物的結構,為交流與開發提供了便利。 2.UML分類 UML圖形主要有用例圖、類圖、順序圖、狀態圖、活動圖。不同的視圖從不同的角度反映系統的特征。 二 用例圖 Use Case Diag ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...