JavaScript进阶内容——BOM详解

在上一篇文章中我们学习了DOM,接下来让我们先通过和DOM的对比来简单了解一下BOM

首先我们先来复习一下DOM:

  • 文档对象模型
  • DOM把文档当作一个对象来看待
  • DOM的顶级对象是document
  • DOM的主要学习是操作页面元素
  • DOM是W3C标准规范

然后我们来介绍一下BOM:

  • 浏览器对象模型
  • BOM把浏览器当作一个对象来看待
  • BOM的顶级对象是window
  • BOM学习的是浏览器窗口交互的一些对象
  • BOM是浏览器厂商在各自浏览器上定义的,兼容性较差

BOM概述

BOM(Browser Object Model)即浏览器对象模型,它提供了独立于内容而与浏览器窗口进行交互的对象,其核心对象是window

BOM由一系列相关的对象构成,并且每个对象都提供了很多方法和属性(BOM包含DOM)

window对象是浏览器的顶级对象,它具有双重角色:

  • 它是JS访问浏览器窗口的一个接口
  • 它是一个全局变量,定义在全局作用域的变量,函数都会变成window对象的属性和方法
  • 在调用时可以省略window,前面学习的对话框都属于window方法,如alert(),prompt()等

代码展示:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <script>
  11. // window是BOM的顶级对象,我们所定义的属性和方法都属于window
  12. // 我们定义一个属性(可以加上window前缀)
  13. var code = 123;
  14. console.log(window.code);
  15. // 我们定义一个方法(可以加上window前缀)
  16. var fn = function() {
  17. // alert也属于window的方法
  18. window.alert('11');
  19. }
  20. window.fn();
  21. </script>
  22. </body>
  23. </html>

窗口加载事件

我们的JavaScript代码常常在HTML和CSS构造之后才会运行,因而JavaScript代码常常放于HTML的body底部

但是window的窗口加载事件可以改变我们的JavaScript书写位置:

  1. window.onload = function(){}
  2. window.addEventListener('load',function(){})

window.onload是窗口加载事件,当文档内容完全加载完成后会触发该事件,调用其内部的处理函数

  1. document.addEventListener('DOMContentLoaded',function(){})

DOMContentLoaded事件触发,代表仅当DOM加载完毕(不包括图片,flash等)就会执行内部处理函数

注意:

  • 我们在有了window.onload和DOMContentLoaded后可以将JavaScript代码放于页面元素上方
  • window.onload只能书写一次,取最后一次书写为准;但window.addEventListener('load',function(){})可以多次书写
  • DOMContentLoaded会在图片加载前就完成相关操作,提升用户体验

代码展示:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <!-- 正常情况下,我们的script应该写在body末尾,写在这个部分是无法正常使用的 -->
  11. <script>
  12. // 这时就需要采用页面加载事件来等待页面加载完成后再去加载JavaScript内容
  13. // window.onload方法在整个script中只能使用一次,不推荐
  14. window.onload = function() {
  15. // 在里面书写内容
  16. var but = document.querySelector('button');
  17. but.onclick = function(){
  18. alert('我是弹窗')
  19. }
  20. }
  21. // window.addEventListener('load',function(){})可以多次调用,推荐使用
  22. window.addEventListener('load',function(){
  23. alert('页面内容加载完成');
  24. })
  25. // document.addEventListener('DOMContentLoaded',function(){})仅针对DOM的加载,DOM加载后即可使用
  26. document.addEventListener('DOMContentLoaded',function(){
  27. alert('DOM内容加载完成');
  28. })
  29. </script>
  30. <button>点我弹出弹窗</button>
  31. </body>
  32. </html>

调整窗口大小事件

我们通过手动拉扯页面边框可以调整页面大小:

  1. window.onresize = function(){}
  2. window.addEventListener('resize',function(){})

window.onresize是调整窗口大小加载事件,当触发时调用内部处理函数

注意:

  • 只要窗口发生像素变化,就会触发该事件
  • 我们常常利用这个事件完成响应式布局,window.innerWidth表示当前屏幕宽度

代码展示:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. <!-- 我们设置一下div的大小,我们希望页面小于一定程度,div消失 -->
  9. <style>
  10. div {
  11. height: 200px;
  12. width: 200px;
  13. background-color: pink;
  14. }
  15. </style>
  16. </head>
  17. <body>
  18. <script>
  19. window.addEventListener('load',function(){
  20. // 页面调整大小有两种语法
  21. // window.onresize = function(){}
  22. // window.addEventListener('resize',function({}))
  23. // 其中resize就是调整窗口加载事件,当触发就调用的处理函数
  24. window.addEventListener('resize',function(){
  25. console.log('页面变化了');
  26. })
  27. // 我们希望页面宽度小于800,div隐藏
  28. var div = document.querySelector('div');
  29. window.addEventListener('resize',function(){
  30. if(window.innerWidth < 800){
  31. div.style.display = 'none';
  32. } else {
  33. div.style.display = 'block';
  34. }
  35. })
  36. })
  37. </script>
  38. <div></div>
  39. </body>
  40. </html>

定时器

window对象为我们提供了两种定时器:

  • Timeout
  • Interval

回调函数

在讲解定时器之前,我们先来了解一下回调函数:

  • 回调函数callback
  • 回调函数常常是指其他内容完成之后,在一定条件下再重新调用该函数
  • 例如我们之前讲到的click事件后的函数,在我们点击某对象后才会触发;也比如我们下面即将讲到的定时器,在一定时间之后才运行的函数,被称为回到函数

Timeout定时器

Timeout分为创建和停止:

  1. //创建方法:
  2. window.setTimeout(调用函数,[延迟毫秒数])
  3. //停止方法:
  4. window.clearTimeout(timeout ID)

setTimeout讲解:

  • setTimeout()用来设置一个定时器
  • 该定时器在定时器到期后执行调用函数
  • 这个调用函数可以直接写函数,可以写函数名两种形式调用
  • 延迟的默认毫秒数为0,即如果不写延迟毫秒数,默认为立即触发状态,但该函数仍旧被认为是回调函数
  • 因为定时器较多,我们常常为定时器设置var变量标识符,同时Timeout的定时器停止中的timeout ID就是指该标识符

clearTimeout讲解:

  • clearTimeout()方法用来取消之前设置的Timeout定时器

注意:

  • Timeout的内置函数仅执行一次!

代码展示:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <button>点击我停止计时器</button>
  11. <script>
  12. // 定时器方法:window.setTimeout(调用函数,{延迟毫秒}),window可以省略
  13. setTimeout(function(){
  14. console.log('3s到了');
  15. },2000)
  16. // 当毫秒数不设置时,默认为0,立即触发
  17. setTimeout(function(){
  18. console.log('立刻触发');
  19. })
  20. // 定时器函数可以是外部函数
  21. function timeback(){
  22. console.log('6s到了');
  23. }
  24. // 我们为了区分定时器,常常会加上标识符
  25. // 当你定义时,这个setTimeout自动开始计时
  26. var timer1 = setTimeout(timeback,6000);
  27. // 我们也可以取消掉定时器setTimeout
  28. // 首先我们定义定时器
  29. var timer = setTimeout(function() {
  30. console.log("10s后爆炸!");
  31. },10000)
  32. // 获得button,在button上捆绑上停止计时器的操作
  33. var button = document.querySelector('button');
  34. button.addEventListener('click',function(){
  35. clearTimeout(timer);
  36. })
  37. </script>
  38. </body>
  39. </html>

Interval定时器

Interval分为创建和停止:

  1. //创建方法:
  2. window.setInterval(调用函数,[延迟毫秒数])
  3. //停止方法:
  4. window.clearInterval(Interval ID)

setInterval讲解:

  • setInterval()用来设置一个定时器
  • 该定时器在定时器到期后执行调用函数
  • 这个调用函数可以直接写函数,可以写函数名两种形式调用
  • 延迟的默认毫秒数为0,即如果不写延迟毫秒数,默认为立即触发状态,但该函数仍旧被认为是回调函数
  • 因为定时器较多,我们常常为定时器设置var变量标识符,同时Timeout的定时器停止中的timeout ID就是指该标识符

clearInterval讲解:

  • clearInterval()方法用来取消之前设置的Interval定时器

注意:

  • Timeout的内置函数会多次执行直至被终止!

代码展示:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <button class="begin">点击我开启定时器</button>
  11. <button class="end">点击我终止计时器</button>
  12. <script>
  13. var begin = document.querySelector('.begin');
  14. var end = document.querySelector('.end');
  15. // 注意需要把setInterval的名称定义在外面,使其变为全局变量
  16. var timer = null;
  17. begin.addEventListener('click',function(){
  18. // setInterval(回调函数,【间隔秒数】)
  19. timer = setInterval(function(){
  20. console.log('1s');
  21. },1000);
  22. })
  23. end.addEventListener('click',function(){
  24. clearInterval(timer);
  25. })
  26. </script>
  27. </body>
  28. </html>

JavaScript执行机制

在了解JavaScript的执行机制前,我们需要先了解JavaScript的基本信息:

  • JavaScript是单线程,在同一时间只能做一件事
  • 因为我们JavaScript是为了操作DOM和BOM,我们在进行操作时不可能同时创建和删除,所以JavaScript被设置为单线程
  • 但是,JavaScript的单线程注定了JavaScript的效率低下,我们的所有任务都需要进行排队,但如果其中有一项任务等待时间较长,就会导致后面的任务不进行,造成页面渲染不连贯

所以在HTML5中,允许JavaScript脚本建立多个线程,于是出现了同步和异步:

  • 同步:

    • 前一个任务执行完毕后,后一个任务才能执行
  • 异步:
    • 可以同时处理多个任务

同时也就区分出同步任务和异步任务:

  • 同步任务:

    • 同步任务都在主线程上执行,形成一个执行线
  • 异步任务:
    • JS的异步任务都是通过回调函数执行的
    • 一般而言异步任务分为:
      • 普通事件 : 如click,resize等
      • 资源加载 : 如load,error等
      • 定时器: 包括Timeout,Interval等

因而JavaScript的执行机制如下:

  1. 先执行执行栈中的同步任务
  2. 异步任务(回调函数)放入任务队列中
  3. 一旦执行栈的所有同步任务执行完毕,系统就会按照次序读取任务队列中的异步任务,于是被读取的异步任务结束等待状态,加载进执行栈的末尾并开始执行

我们给出一张图片来解释上述内容:

location对象

在学习location对象之前,我们先来了解一下URL:

  • 统一资源定位符(URL)是互联网上标准资源的地址.
  • 互联网上的每个文件都有一个唯一的URL,它包含的信息指出文件的位置以及浏览器应该怎么处理它
  1. protocol://host[:port]/path/[?query]#fragment
  2. http://www.itcast.cn/index.html?name=andy&age=18#link
组成 说明
protocol 通信协议 常用的http,ftp,maito
host 主机(域名)
port 端口号 可选. 省略时使用方案的默认端口
path 路径 由零个或多个'/'隔开的字符串,一般用来表示主机上的一个目录或文件地址
query 参数 以键值对的形式,用&隔开
fragment 片段 #后面内容常用于连接 锚点

在了解了URL之后我们来介绍一下location:

  • window对象为我们提供了一个location属性用来获得或设置窗体的URL,并且可以用来解析URL
  • 因为这个属性返回的是一个对象,所以我们也将该属性称为location对象,我们可以直接输出location获得对象,也可以采用属性方法获得其内容
location对象属性和方法 返回值
location.href 获得或设置 整个URL
location.host 返回主机(域名)
location.port 返回端口号 若没有返回空字符串
location.pathname 返回路径
location.search 返回参数
location.hash 返回片段
location.assign 和href,用来跳转页面(附带历史记录)
location.replace 和href,用来跳转页面(不附带历史记录)
location.reload 重新加载该页面(ctrl+F5)

代码展示:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. <--我们希望点击该按键后,出现提示n秒后跳转页面,并在倒计时结束后跳转页面-->
  9. </head>
  10. <body>
  11. <button>点击我5s后跳转页面</button>
  12. <div></div>
  13. <script>
  14. var button = document.querySelector('button');
  15. var div = document.querySelector('div');
  16. button.addEventListener('click',function(){
  17. // 在点击后,出现倒计时:
  18. var time = 5;
  19. setInterval(function(){
  20. if(time == 0){
  21. //在这里我们使用href来跳转页面
  22. location.href = 'https://www.baidu.com/';
  23. } else {
  24. // 这里注意div修改文字用innerHTML
  25. div.innerHTML = '还剩下' + time + '秒后跳转页面';
  26. time--;
  27. }
  28. },1000)
  29. })
  30. </script>
  31. </body>
  32. </html>
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. <--这部分我们来讲解location的三种方法-->
  9. </head>
  10. <body>
  11. <button>assign</button>
  12. <button>replaca</button>
  13. <button>reload</button>
  14. <script>
  15. var buttons = document.querySelectorAll('button');
  16. // assign跳转页面,且保留历史记录
  17. buttons[0].addEventListener('click',function(){
  18. location.assign('https://www.baidu.com/');
  19. })
  20. // replace跳转页面,不保留历史记录
  21. buttons[1].addEventListener('click',function(){
  22. location.replace('https://www.baidu.com/');
  23. })
  24. // reload刷新页面,类似于ctrl+f5
  25. buttons[2].addEventListener('click',function(){
  26. location.reload();
  27. })
  28. </script>
  29. </body>
  30. </html>

navigator对象

navigator对象包含有关浏览器的信息,它有很多属性,我们最常用的是userAgent,该属性可以返回由客户机发给服务器的user-agent头部信息,用来判断你目前使用的机型

我们常用下述代码来判断你打开的网页是电脑端还是手机端:

  1. if(navigator.userAgent.match(各种手机品牌)) {
  2. //如果是手机,就转到手机端页面
  3. window.location.href = "https://www.baidu.com/";
  4. } else {
  5. //如果是电脑,就转到电脑端页面
  6. window.location.href = "http://news.baidu.com/";
  7. }

history对象

window对象给我们提供了history对象,与浏览器历史记录进行交互,该对象包含了用户访问过的URL

history对象方法 说明
history.back() 可以后退网页(类似于浏览器自带后退按键)
history.forward() 可以前进网页(类似于浏览器自带前进按键)
history.go(参数) 可以自定义前进后退页面(参数可以是正负数)

结束语

好的,关于BOM的知识我们就讲解到这里,你是否完全明白了呢?

JavaScript进阶内容——BOM详解的更多相关文章

  1. JavaScript进阶内容——DOM详解

    JavaScript进阶内容--DOM详解 当我们已经熟练掌握JavaScript的语法之后,我们就该进入更深层次的学习了 首先我们思考一下:JavaScript是用来做什么的? JavaScript ...

  2. JavaScript(4)---BOM详解

    JavaScript(4)---BOM详解 之前写过一篇有关DOM的博客:JavaScript(2)---DOM详解 DOM有个顶级对象叫:document.同样BOM中也有顶级对象叫 window. ...

  3. JavaScript正则表达式详解(二)JavaScript中正则表达式函数详解

    二.JavaScript中正则表达式函数详解(exec, test, match, replace, search, split) 1.使用正则表达式的方法去匹配查找字符串 1.1. exec方法详解 ...

  4. Javascript 异步加载详解

    Javascript 异步加载详解 本文总结一下浏览器在 javascript 的加载方式. 关键词:异步加载(async loading),延迟加载(lazy loading),延迟执行(lazy ...

  5. 【JavaScript中的this详解】

    前言 this用法说难不难,有时候函数调用时,往往会搞不清楚this指向谁?那么,关于this的用法,你知道多少呢? 下面我来给大家整理一下关于this的详细分析,希望对大家有所帮助! this指向的 ...

  6. JavaScript中的this详解

    前言 this用法说难不难,有时候函数调用时,往往会搞不清楚this指向谁?那么,关于this的用法,你知道多少呢? 下面我来给大家整理一下关于this的详细分析,希望对大家有所帮助! this指向的 ...

  7. Javascript中prototype属性详解 (存)

    Javascript中prototype属性详解   在典型的面向对象的语言中,如java,都存在类(class)的概念,类就是对象的模板,对象就是类的实例.但是在Javascript语言体系中,是不 ...

  8. Javascript常用的设计模式详解

    Javascript常用的设计模式详解 阅读目录 一:理解工厂模式 二:理解单体模式 三:理解模块模式 四:理解代理模式 五:理解职责链模式 六:命令模式的理解: 七:模板方法模式 八:理解javas ...

  9. (转)javascript中event对象详解

    原文:http://jiajiale.iteye.com/blog/195906 javascript中event对象详解          博客分类: javaScript JavaScriptCS ...

随机推荐

  1. SpringJDBC和事务控制

    SpringJDBC和事务控制 主要内容 1.基本配置 <!--依赖导入--> <dependencies> <!-- 添加相关的依赖坐标 --> <!-- ...

  2. 关于控制台报错“Cannot use import statement outside a module”问题的解决

    问题还原: 1.首先在main.js里 使用ES6语法import引入另外一个js模块. 2.此时将main.js在index.html中通过script标签引入,如下 3.右键通过vscode提供的 ...

  3. CSAPP 之 DataLab 详解

    前言 本篇博客将会剖析 CSAPP - DataLab 各个习题的解题过程,加深对 int.unsigned.float 这几种数据类型的计算机表示方式的理解. DataLab 中包含下表所示的 12 ...

  4. 你不知道的JS 中——yield

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. Oracle 19c单实例部署

    目录 Oracle 19c单实例部署: 1.配置yum: 2.安装rpm包: 3.设置hostname: 4.配置hostname解析: 5.配置时钟同步服务(ntp): 6.检查及配置内核参数: 7 ...

  6. python DOS 攻击,TCP压测脚本

    pip3 install string&&scapy 1 #!/usr/bin env python 2 #-*-coding:utf-8-*- 3 import socket,ran ...

  7. MySQL 的 EXPLAIN 语句及用法

    在MySQL中 DESCRIBE 和 EXPLAIN 语句是相同的意思.DESCRIBE 语句多用于获取表结构,而 EXPLAIN 语句用于获取查询执行计划(用于解释MySQL如何执行查询语句). 通 ...

  8. 利用ArcEngine开发地图发布服务,将mxd文档一键发布成wmts,并根据需要对地图进行空间查询,返回客户端geojson

    一直想开发一个软件取代ArcGIS Server,该软件使用ArcEngine开发,以Windows Service形式发布,部署在服务端上,解决wmts地图服务发布和空间查询的问题,经过不断的研究. ...

  9. map计算

    map理解 参考1: https://github.com/rafaelpadilla/Object-Detection-Metrics 参考2:https://github.com/rafaelpa ...

  10. Pandas复杂查询、数据类型转换、数据排序

    Pandas高级操作 1.复杂查询 (1)逻辑运算 以DataFrame其中一列进行逻辑计算,会产生一个对应的bool值组成的Series 于是我们可以利用返回的bool列表进行一系列的数据查询 (2 ...