JS之BOMBOM!

来源:https://www.cnblogs.com/lczuishuai/archive/2019/03/15/10536054.html
-Advertisement-
Play Games

什麼是BOM? bom即browser object model 也就是瀏覽器對象模型,BOM由多個對象組成,其中代表瀏覽器視窗的window對象是BOM的頂層對象,其他對象都是該對象的子對象。 頂層對象:window 子對象:location:location 對象包含有關當前 URL 的信息; ...


什麼是BOM?

  bom即browser object model 也就是瀏覽器對象模型,BOM由多個對象組成,其中代表瀏覽器視窗的window對象是BOM的頂層對象,其他對象都是該對象的子對象。

  頂層對象:window

  子對象:location:location 對象包含有關當前 URL 的信息;

      history:History 對象包含用戶(在瀏覽器視窗中)訪問過的 URL;

      screen:Screen 對象包含有關用戶屏幕的信息;

      navigator:Navigator 對象包含有關訪問者瀏覽器的信息;

      document:Document 對象使我們可以從腳本中對 HTML 頁面中的所有元素進行訪問;

      event:Event 對象代表著事件對象的狀態。

 一.window對象:

  (一)alert警告框

    語法:window.alert();或 alert();

    功能:顯示一段帶有消息和確認按鈕的警告框

  (二)confirm選擇框

    語法:window.confirm();或 confirm();

    功能:顯示一個帶有指定消息的和確定及取消按鈕的對話框

    返回值:用戶點擊確定,confirm()返回true

        用戶點擊取消,confirm()返回false

  (三)prompt輸入框

    語法:window.prompt(text[,defaultText]);或者 prompt(text,[,defaultText]);

    參數:text:要在對話框中顯示的純文本(不是HTML格式文本)

         defaultText:預設的輸入文本

    返回值:如果用戶點擊提示框的取消按鈕,則返回null

        如果用戶點擊確定按鈕,則返回輸入的內容

  (四)open打開一個新視窗

    語法:window.open(pageURL,name,parameters)

    功能:打開一個新的瀏覽器視窗或者查找一個名稱的視窗

    參數:pageURL:子視窗路徑

       name:子視窗的名字

       parameters:視窗參數(各參數用逗號分隔)

          width:視窗寬度,

          height:視窗高度,

          left:視窗X軸坐標 ;top:視窗Y軸坐標,

          toolbar:是否顯示瀏覽器工具欄(yes/no),

          menubar:是否顯示菜單欄(yes/no),

          scrollbars:是否顯示滾動條(yes/no),

          location:是否顯示地址欄位,

          status:是否添加狀態欄,

  (五)close關閉瀏覽器

    語法:window.close();

    功能:關閉瀏覽器視窗

  (六)setTimeout超時調用

    語法:setTimeout(code,millisec);

    功能:在指定的毫秒數後調用函數或計算表達式

    參數:code:要調用的函數名或要執行的js代碼串

       millisec:在執行代碼前需等待的時間(毫秒)

PS:setTimeout()只執行code一次,如果要多次調用請使用setInterval()或者讓code自己調用自己;

  (七)clearTimeout清除超時調用

    語法:clearTimeout(id_of_settimeout);

    功能:取消由setTimeout()方法設置的超時調用;

    參數:id_of_settimeout:由setTimeout()返回的ID值,該值標識要取消的延遲代碼塊

  (八)setInterval間歇調用

    語法:setInterval(code,millisec)

    功能:每隔指定的時間執行一次代碼

    參數:code:要調用的函數名或要執行的js代碼串

       millisec:在執行代碼前需要等待的時間(毫秒)

  (九)clearInterval清除間歇調用

    語法:clearInterval(id_of_setinterval)

 

二.location對象

  location對象提供了與當前視窗中載入的文檔有關的信息,還提供了功能,它既是window對象的屬性,也是document對象的屬性

  (一)location.href獲取url

    1.獲取url

      語法:location.href

      功能:返回當前載入頁面完整url

      說明:location.href()與window.location.href()等價

    2.設置url

      語法:location.href = "url"

      功能:使網頁載入到指定的url地址上

  (二)location.hash獲取錨點鏈接

    1.獲取錨點

      語法:location.hash

      功能:返回url中的hash(#以及後面的字元),如果不包含,返回空字元串

    2.設置錨點

      語法:location.hash = "param";

      功能:為url添上指定的錨點,實現頁面上的錨點位置跳轉

  (三)location對象其他常用屬性

     # TODO 待補充

  (四)location.replace重新定向url

    語法:location.replace(url)

    功能:重新定向url

    PS:使用location.replace不會在歷史記錄中生產新記錄(沒有後退按鈕)

  (五)location.reload重新載入當前顯示的頁面

    語法:location.reload()

    功能:重新載入當前顯示的頁面

    說明:location.reload()有可能從瀏覽器緩存中載入

       location.reload(true)強制從伺服器重新載入

三,history對象

  history對象保存了用戶在瀏覽器中訪問頁面的歷史記錄

  (一)history.back()

    語法:history.back()

    功能:回到歷史記錄的上一步

    PS:相當於使用了history.go(-1)

  (二)history.forward()

    語法:history.forward()

    功能:回到歷史記錄的下一步

    PS:相當於使用了history.go(1)

  (三)history.go(-n)

    語法:history.go(-n)

    功能:回到歷史記錄的前n步 

  (四)history.go(n)

    語法:history.go(n)

    功能:去到歷史記錄的後n步

四,screen對象

  screen對象包含有關客戶端顯示屏幕的信息  

  (一)screen.availWidth(可用屏幕寬度)和screen.availHeight(可用屏幕高度)

 

  (二)screen.innerWidth(視窗文檔顯示寬度);screen.innerHeight(視窗文檔顯示高度)

五,navigator對象

  提供了用戶的瀏覽器,操作系統等信息,可通過當前對象得知用戶所用瀏覽器類型,版本等

  (一)navigator.userAgent用來識別瀏覽器名稱,版本,引擎以及操作系統等信息

    語法:navigator.userAgent

    例子:

 


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

-Advertisement-
Play Games
更多相關文章
  • # jQuery $.on()方法和addEventListener改變this指向 ...
  • 1.語義標簽解決方案 <video></video> 屬性: controls 顯示控制欄 autoplay 自動播放 loop 設置迴圈播放 多媒體標簽在網頁中的相容效果方式 <video> <source src="1.mp4"></source> <source src="1.ogg"></s ...
  • 在簡介、引言中常見:文字只有一排,超出寬度以省略號顯示,像這樣 實現方法:在公共庫定義otw類 其中 text-overflow:ellipsis 顯示省略符號來代表被修剪的文本; white-space:nowrap 文本不會換行,文本會在在同一行上繼續,直到遇到 <br> 標簽為止。 ...
  • 今天我們繼續瞭解我們攻城獅(Ps.工程師)蓋房子(Ps.寫網頁)的時候所需要的建材(Ps.標簽),今天我們先來瞭解一下標簽的種類。 我們在寫網頁的工程中,需要用到各種各樣的標簽,這些標簽也有自己不同的特性,從微觀上講它們不同的特性可以適應不同的頁面情況;從巨集觀上講,它們分為塊級元素回合行內元素。 今 ...
  • 電商項目(上) css3新增選擇器: 選取屬於其父元素的首個子元素的指定選擇器 選取屬於其父元素的最後一個子元素的指定選擇器 匹配屬於其父元素的第n個子元素 選擇器匹配屬於其元素的第n個子元素的每個元素 定義文檔的頁面 定義導航鏈接的部分 定義文檔或節的頁腳 定義文檔中的節 定義其所處內容之外的內容 ...
  • 今天我們將介紹mode屬性的development值。它會自動為你配置Webpack以簡化開發過程。除此之外,我們還會介紹webpack-dev-server——包括模塊熱替換。開始吧! ...
  • 這個主要是自己遇到很多次了,每次都去網上查改哪裡,這次記到自己這裡吧,以後把遇到的vue工具的一些問題都整理到這裡 在vue中開發的項目有時候需要到手機上看效果,但是你配好本地埠之後,會出現訪問內容 Invalid Host header 這時候需要在 webpack-dev.config.js中 ...
  • 1.傳統方式 >原型鏈 (過多繼承了沒用的屬性) Grand.prototype.lastname = 'zhang' function Grand(); } var grand = new Grand(); Father.prototype = grand; function Father(){ ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...