JavaScript-Window對象

Window對象

BOM:瀏覽器對象模型

定時器-延時函數

JavaScript內置的一個用來讓代碼延遲執行的函數,setTimeout

setTimeout(回調函數,等待的毫秒數);

setTimeout僅僅只執行依次,所以可以理解為就是把一段代碼延遲執行,平時省略window

清除延遲函數:

let timer = setTimeout(回調函數,等待的毫秒數);
clearTimeout(timer);

兩種定時器的對比

執行次數

  • 延時函數:執行一次
  • 間歇函數:每隔一段時間就執行一次,除非手動清除

JS執行機制

JavaScript 語言的一大特點就是單線程,也就是說,同一時間只能做一件事情

這是因為Javascript 這門腳本語言誕生的使命所致一avaScript 是為處理頁面中用戶的交互,以及操作
DOM 而誕生的。比如我們對某個 DOM 元素進行添加和刪除操作,不能同時進行。應該先進行添加,之后再刪除。
單線程就意味著,所有任務需要排隊,前一個任務結束,才會執行后一個任務。這樣所導致的問題是: 如
果JS 執行的時間過長,這樣就會造成頁面的渲染不連貫,導致頁面渲染加載阻塞的感覺。

為了解決這個問題,利用多核CPU的計算能力,HTML5提出了WebWorker標準,允許JavaScript腳本創建多個線程,于是,JS中出現了同步和異步

執行過程:先執行執行棧中的同步任務,異步任務放入到任務隊列中,同步任務執行完畢后再去隊列中執行任務隊列任務

在這里插入圖片描述

事件循環(event loop)

location對象

location的數據類型時對象,它拆分并保存了URL地址的各個組成部分

常用屬性和方法:

href 屬性獲取完成的URL地址,對其賦值時用于地址的跳轉

location.herf='https://www.baidu.com';

search屬性獲取地址中攜帶的參數,符號?后面部分

location.search

hash屬性獲取地址中的哈希值,符號#后面部分

baidu.com#/my
location.hash //   #/my

reload():刷新當前頁面,傳入參數true時,表示強制刷新

//點擊按鈕,刷新頁面
let btn = document.querySelect('button');
btn.addEventListener('click',function(){location.reload(true);//傳入參數true  強制刷新頁面(類似于ctrl+F5)
})

navigator對象

數據類型時對象,該對象下記錄了瀏覽器自身的相關信息

常用屬性和方法

通過userAgent屬性檢測瀏覽器的版本及平臺

檢測瀏覽器信息:

!(function(){const userAgent = navigator.userAgent;const android = userAgent.match(/(Android);?([¥s¥/]+[¥d.]+)?/);const iphone = userAgent.match(/(iPhone¥sOS)¥s([¥d_]+)/);if(android || iphone){location.href='http://m.itcast.cn';}
})();

histroy對象

histroy的數據類型是對象,主要管理歷史記錄,該對象與瀏覽器地址欄的操作相對應,如前進,后退,歷史記錄等等

常用的屬性和方法:

hostroy對象方法作用
back()可以后退功能
forward()前進功能
go(參數)前進或后退功能(1:前進一個頁面,-1:后退一個頁面)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/211966.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/211966.shtml
英文地址,請注明出處:http://en.pswp.cn/news/211966.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

網絡協議疑點記錄

1.RIP, OSPF,BGP 首先什么是自治系統:治系統就是幾個路由器組成了一個小團體 ?,小團體內部使用專用的協議進行通信,而小團體和小團體之間也使用專用的協議進行通信。 IGP RIP 距離矢量路由算法,bellman-ford算法,每個路由節點知道全局的路由信息,通過和鄰居交換信息得…

五.單行函數

單行函數 1.函數的理解1.1什么是函數1.2不同DBMS函數的差異1.3MySQL的內置函數分類 2.數值函數2.1基本函數2.2角度與弧度互換函數2.3三角函數2.4指數與對數2.5進制間的轉換 3.字符串函數4.日期和時間函數4.1獲取日期、時間4.2日期與時間戳的轉換4.3獲取月份、星期、星期數、天數…

perl處理base64、md5、SHA-1、SHA-256的計算

使用perl可以進行base64、md5、SHA-1、SHA-256的計算,使用也非常方便,下面是示例代碼: #! /usr/bin/perl use v5.14; use MIME::Base64; use Digest;my $test_str hello world;# 測試base64 say encode_base64($test_str);# 測試md5 my $md…

【Copilot】Edge瀏覽器的copilot消失了怎么辦

這種原因,可能是因為你的ip地址的不在這個服務的允許范圍內。你需要重新使用之前出現copilot的ip地址,然后退出edge的賬號,重新登錄一遍,最后重啟edge,就能夠使得copilot側邊欄重新出現了。

【已解決】ModuleNotFoundError: No module named ‘pandas‘

問題描述 ModuleNotFoundError: No module named ‘pandas’ 解決辦法 pip install pandas 完結撒花 熟悉的人相遇,就像久旱等到的甘霖

計算機基礎知識66

Auth的補充 #概念:是django 的一個app,關于用戶的登錄,退出,注冊... # 配置文件中配置:表會被遷移 INSTALLED_APPS [django.contrib.auth,] # auth有哪些表---權限控制: Permission:auth_permi…

Java 中連接 SQL 數據庫

在 Java 中,連接 SQL 數據庫通常使用 JDBC(Java Database Connectivity)。以下是使用 IntelliJ IDEA 連接 SQL 數據庫的一般步驟: 1. 引入 JDBC 驅動:首先,你需要下載并引入與你所使用的數據庫相對應的 JD…

Linux 導入、導出 MySQL 數據庫命令

一、導出數據庫 1、導出完整數據:表結構數據 mysqldump -u用戶名 -p 數據庫名 > 數據庫名.sql 舉例:以下命令可以導出 abc 數據庫的數據和表結構 /usr/local/mysql/bin/mysqldump -uroot -p abc > abc.sql2、只導出表結構 mysqldump -u用戶名 -p…

用23種設計模式打造一個cocos creator的游戲框架----(十二)狀態模式

1、模式標準 模式名稱:狀態模式 模式分類:行為型 模式意圖:允許一個對象在其內部狀態改變時改變它的行為。對象看起來似乎修改了它的類。 結構圖: 適用于: 1、一個對象的行為決定于它的狀態,并且它必須…

【C語言】字符串函數strcpystrcatstrcmpstrstr的使?和模擬實現

🌈write in front :🔍個人主頁 : 啊森要自信的主頁 ??真正相信奇跡的家伙,本身和奇跡一樣了不起啊! 歡迎大家關注🔍點贊👍收藏??留言📝>希望看完我的文章對你有小小的幫助&am…

OCSP檢查數字證書狀態詳解

文章目錄 1. OCSP 的基本原理2. OCSP 的工作流程3. OCSP 的優勢和不足4. OCSP Stapling5. OCSP 配置 OCSP(Online Certificate Status Protocol)是一種用于檢查數字證書狀態的協議。它提供了一種實時查詢證書狀態的方式,以確定證書是否被吊銷…

prototype、__proto__、constructor、原型、原型鏈

結論: __proto__和constructor屬性是對象所獨有的; prototype屬性是函數所獨有的,由于函數也是一種對象,所以函數也擁有__proto__和constructor屬性;__proto__屬性的作用就是當訪問一個對象的屬性時,如果該…

C++ 多態性(Polymorphism)和 虛函數(Virtual Functions)

在 C 中,多態性(Polymorphism)是面向對象編程的一個重要概念,它允許通過基類指針或引用來調用派生類對象的特定方法。虛函數(Virtual Functions)是實現多態性的一種機制,通過在基類中聲明虛函數…

InputStream和OutputStream速通

InputStream和OutputStream 輸入流(InputStream): InputStream是抽象類,用于從各種數據源(如文件、網絡連接、內存等)讀取字節流。常見的子類包括FileInputStream、ByteArrayInputStream和SocketInputStrea…

電源小白入門學習1——電源系統架構和相關指標

電源小白入門學習1——電源系統架構和相關指標 電源系統架構電源系統的指標及測量方法電源的效率電源的靜態電流輸出電壓調整率紋波測量的注意事項動態負載測試 在開始本期內容之氣,我先簡單介紹一下我們電源小白學習系列內容:首先我是一個嵌入式小白&am…

【InsCode】新的代碼管理工具inscode教程它和Git以及SVN的區別

InsCode 實踐分享 InsCodeGitSVN類型代碼管理工具分布式版本控制系統集中式版本控制系統分支管理支持強大的分支管理功能,包括創建、合并和刪除分支支持分支管理,操作簡單快捷支持分支管理,但操作相對復雜代碼托管提供代碼托管功能&#xff…

在VSCode中運行Python腳本文件時如何傳參

以下實驗所處的操作系統環境說明: OS版本MacOSMonterey 12.1VSCodeOctober 2023 (version 1.84.2) 一、背景 在 VSCode 中寫好 Python 腳本后,如果要運行起來,可以怎么做呢? 一般有以下幾種方式: 1、直接在 VSCode…

sentinel整合nacos配置中心持久化

在網上找了很多的資料,發現sentinel整合nacos持久化的博文和視頻大多數都只有改造限流部分的教程,并且都需要修改前端,略顯麻煩,至于剩下的熔斷、熱點流控、授權的更是沒有相關的改造教程,最后在知乎的看到一篇文章后讓…

百科詞條可以刪除嗎?如何刪除自己的百度百科?

近日,小馬識途營銷顧問接到不少客戶刪除自己百科詞條的咨詢,有不少人自己并沒有去建立百科詞條,但是網上已經有了,有的信息不正確,甚至有的信息是負能量的,對當事人自己造成一定的困擾,所以尋求…

pytorch學習4-簡易卷積實現

系列文章目錄 pytorch學習1-數據加載以及Tensorboard可視化工具pytorch學習2-Transforms主要方法使用pytorch學習3-torchvisin和Dataloader的使用pytorch學習4-簡易卷積實現pytorch學習5-最大池化層的使用pytorch學習6-非線性變換(ReLU和sigmoid)pytorc…