【JS基础】BOM基础操作、js的执行机制

举报
人才程序员 发表于 2024/01/29 08:15:37 2024/01/29
【摘要】 @TOC 前言在Web开发中,JavaScript的BOM(浏览器对象模型)扮演着关键的角色,为开发者提供了与浏览器交互的能力。BOM包含了许多对象,如window、navigator、location等,通过它们我们可以控制浏览器的行为、获取用户信息以及进行页面导航等操作。本文将探讨JS基础中BOM的基础操作,让我们一起深入了解如何充分利用这些对象来实现更强大的Web应用。 一、BOM是什...

@TOC


前言

在Web开发中,JavaScript的BOM(浏览器对象模型)扮演着关键的角色,为开发者提供了与浏览器交互的能力。BOM包含了许多对象,如window、navigator、location等,通过它们我们可以控制浏览器的行为、获取用户信息以及进行页面导航等操作。本文将探讨JS基础中BOM的基础操作,让我们一起深入了解如何充分利用这些对象来实现更强大的Web应用。


一、BOM是什么

BOM(浏览器对象模型)就像是你和浏览器打交道的工具箱。在这个工具箱里,有各种各样的工具,帮助你控制浏览器的行为,获取用户的信息,甚至可以改变当前页面的内容。比如,你可以用BOM告诉浏览器弹出一个新窗口,或者获取用户所在地的信息。总的来说,BOM就是让你在JavaScript中可以跟浏览器互动的一组工具。

二、定时器-setTimeout

JavaScript内置的一个用来让代码延迟执行的函数,叫 setTimeout
语法:

setTimeout(回调函数,等待的毫秒数)

setTimeout 仅仅只执行一次,所以可以理解为就是把一段代码延迟执行,平时省略window
清除延时函数:

let timer = setTimeout(回调函数,等待的毫秒数)
clearTimeout(timer)

三、js的执行机制-事件循环

JavaScript 语言的一大特点就是单线程,也就是说,同一个时间只能做一件事。
这是因为Javascript 这门脚本语言诞生的使命所致一javacript 是为处理页面中用户的交互,以及操作
DOM 而诞生的。比如我们对某个 DOM 元素进行添加和删除操作,不能同时进行。 应该先进行添加,之后
再删除。
单线程就意味着,所有任务需要排队,前一个任务结束,才会执行后一个任务。这样所导致的问题是:
果JS 执行的时间过长,这样就会造成页面的渲染不连贯,导致页面渲染加载阻塞的感觉。

为了解决这个问题,利用多核 CPU 的计算能力,HTML5 提出 Web Worker 标准,允许JavaScript 脚本创建多个线程。于是,JS 中出现了同步和异步
同步
前一个任务结束后再执行后一个任务,程序的执行顺序与任务的排列顺序是一致的、同步的。比如做饭的同步
做法:我们要烧水煮饭,等水开了 (10分钟之后),再去切菜,炒菜。

异步:
你在做一件事情时,因为这件事情会花费很长时间,在做这件事的同时,你还可以去处理其他事
情。比如做饭的异步做法,我们在烧水的同时,利用这10分钟,去切菜,炒菜。

同步任务
同步任务都在主线程上执行,形成一个执行栈
异步任务
JS的异步是通过回调函数实现的。
一般而言,异步任务有以下三种类型
1、普通事件,如 click、resize 等
2、资源加载,如 load、error 等
3、定时器,包括 setlnterval、setTimeout 等
异步任务相关添加到任务队列中(任务队列也称为消息队列)。

js的执行机制:
1.先执行执行栈中的同步任务
2异步任务放入任务队列中
3.一旦执行栈中的所有同步任务执行完毕,系统就会按次序读取任务队列中的异步任务,于是被读取的异步任务结束等待状
态,进入执行栈,开始执行。

由于主线程不断的重复获得任务、执行任务、再获取任务、再执行,所以这种机制被称为事件循环 ( event loop)

四、localtion对象

4.1 location对象是什么

Location对象就像是地图上的指南针,告诉你当前在哪里。在Web开发中,Location对象告诉你当前浏览器所加载的页面的地址(URL)。通过Location对象,你可以获取到当前页面的URL信息,包括主机名、路径、查询参数等。你还可以使用它来跳转到其他页面,就像在地图上点击一个链接一样,让浏览器加载新的页面。所以,Location对象就是帮助你在浏览器中导航的一个工具。

在这里插入图片描述
常用属性:

href:
作用: 获取或设置整个 URL 地址。
使用:var currentURL = location.href; 获取当前页面的完整URL。

host:
作用: 获取或设置主机名和端口号。
使用: var hostName = location.host; 获取当前页面的主机名和端口号。

hostname:
作用: 获取或设置主机名。
使用: var host = location.hostname; 获取当前页面的主机名。

pathname:
作用: 获取或设置URL的路径部分。
使用: var path = location.pathname; 获取当前页面的路径。

search:
作用: 获取或设置URL的查询参数部分。
使用: var params = location.search; 获取当前页面的查询参数。

常用方法:
assign(url):
作用: 加载新的文档,相当于点击链接或输入新的 URL 地址。
使用: location.assign('https://www.example.com'); 加载指定URL的页面。

reload():
作用: 重新加载当前页面。
使用: location.reload(); 重新加载当前页面。

replace(url):
作用: 用新的文档替换当前文档,但不会在浏览历史中留下新的记录。
使用: location.replace('https://www.example.com'); 用指定URL替换当前页面。

toString():
作用: 返回当前文档的完整 URL。
使用: var currentURL = location.toString(); 获取当前页面的完整URL。
通过这些属性和方法,你可以方便地获取和操作当前页面的URL,实现页面导航、重载以及与浏览器历史的交互。

五、navigator和history对象

5.1 navigator对象

Navigator对象就像是你的设备身份证,告诉网站你所使用的浏览器和设备的详细信息。在Web开发中,Navigator对象提供了许多关于用户环境的信息,比如浏览器类型、版本、操作系统等。
想象一下,当你访问一个网站时,网站可能想知道你是用的什么浏览器,是在什么操作系统下,是不是移动设备,这时候Navigator对象就派上用场了。通过它,网站可以根据用户的环境信息,提供更合适的页面或功能,让用户体验更好。
所以,Navigator对象就是一个提供关于用户设备和浏览器信息的“身份证”,让网站可以更好地适应不同的访问环境。

常用属性:
navigator.userAgent:
作用:返回包含用户代理字符串的字符串,该字符串标识浏览器。
使用方法:

const userAgentString = navigator.userAgent;

navigator.platform:
作用:返回一个字符串,表示浏览器运行的操作系统。
使用方法:

const platform = navigator.platform;

navigator.language:
作用:返回一个字符串,表示浏览器当前使用的语言。
使用方法:

const language = navigator.language;

navigator.cookieEnabled:
作用:返回一个布尔值,表示浏览器是否启用了 cookie。
使用方法:

const isCookieEnabled = navigator.cookieEnabled;

navigator.onLine:
作用:返回一个布尔值,表示浏览器是否处于在线状态。
使用方法:

const isOnline = navigator.onLine;

常用方法:
navigator.geolocation.getCurrentPosition():
作用:获取当前设备的地理位置信息。
使用方法:

navigator.geolocation.getCurrentPosition(successCallback, errorCallback, options);

navigator.mediaDevices.getUserMedia():
作用:请求用户的媒体设备(例如摄像头和麦克风)。
使用方法:

navigator.mediaDevices.getUserMedia(constraints)
  .then(function (stream) {
    // 处理媒体流
  })
  .catch(function (error) {
    // 处理错误
  });

navigator.clipboard.writeText():
作用:将文本写入剪贴板。
使用方法:

navigator.clipboard.writeText(text)
  .then(function () {
    // 写入成功
  })
  .catch(function (error) {
    // 处理错误
  });

navigator.serviceWorker.register():
作用:注册 Service Worker。
使用方法:

navigator.serviceWorker.register('service-worker.js')
  .then(function (registration) {
    // 注册成功
  })
  .catch(function (error) {
    // 处理错误
  });

这只是 navigator 对象的一小部分属性和方法,它还提供了其他一些功能,用于检测硬件设备、浏览器版本等信息,以及一些用于控制浏览器行为的属性和方法。在使用这些属性和方法时,需要根据具体的需求选择合适的方式进行调用。

在这里插入图片描述

5.2 history对象

history 对象用于在浏览器窗口之间保存和导航会话历史记录。它是浏览器的一部分,提供了一些属性和方法,使开发者可以在 JavaScript 中操纵浏览器的历史记录。以下是 history 对象的一些常用属性和方法:

常用属性:
history.length:
作用:返回会话历史中的条目数量,即当前页面在历史记录中的位置。
使用方法:

const historyLength = history.length;

history.state:
作用:返回当前条目的状态对象。这是在使用 pushState() 或 replaceState() 方法时关联到当前历史条目的一个对象。
使用方法:

const currentState = history.state;

常用方法:
history.back():
作用:导航到会话历史中的上一个页面,相当于用户点击浏览器的后退按钮。
使用方法:

history.back();

history.forward():
作用:导航到会话历史中的下一个页面,相当于用户点击浏览器的前进按钮。
使用方法:

history.forward();

history.go():
作用:根据指定的参数在会话历史中移动页面,可以是正数(前进)或负数(后退)。
使用方法:

// 后退一步
history.go(-1);

// 前进一步
history.go(1);

// 移动到历史中的第三个条目
history.go(2);

history.pushState():
作用:向会话历史栈中添加一个新条目,并设置相关的状态对象和标题。
使用方法:

history.pushState(stateObject, title, url);

history.replaceState():
作用:用新的状态对象和标题替换当前的历史条目。
使用方法:

history.replaceState(stateObject, title, url);

这些方法和属性允许你以编程方式操纵浏览器的历史记录,而不需要用户手动点击浏览器的后退或前进按钮。使用这些方法需要注意不要滥用,以免导致用户体验问题。

六、localstorage对象

localStorage 是 Web Storage API 提供的一种用于在浏览器中存储键值对的对象。它允许开发者在用户的本地浏览器上永久性地存储数据,以便在页面刷新或重新打开时仍然可用。localStorage 是一个简单的键值对存储系统,类似于传统的 JavaScript 对象,但具有持久性。

特点和用途:
持久性: 数据存储在用户的本地浏览器中,不受页面刷新或关闭的影响。数据会一直存在,直到通过代码或用户手动删除。

容量: 每个域名下的 localStorage 共享相同的存储空间,通常为 5MB。这意味着开发者需要谨慎使用,以避免超出存储限制。

同源策略: localStorage 遵循同源策略,即只有在相同协议、主机和端口的页面之间共享。这有助于保护用户的数据安全性。

基本操作:
设置值:

localStorage.setItem('key', 'value');

获取值:

const value = localStorage.getItem('key');

移除值:

localStorage.removeItem('key');

清空所有值:

localStorage.clear();

使用示例:

// 存储数据
localStorage.setItem('username', 'JohnDoe');

// 获取数据
const username = localStorage.getItem('username');
console.log('Username:', username);

// 移除数据
localStorage.removeItem('username');

需要注意的是,localStorage 存储的数据是以字符串形式存储的。如果需要存储对象或其他数据类型,通常需要将其转换为字符串形式(例如,使用 JSON.stringify)在存储时,然后在获取时再进行相应的解析(例如,使用 JSON.parse)。这有助于保持存储的数据结构。


总结

BOM的基础操作对于JavaScript开发者来说是必备的技能之一。通过熟练掌握window对象、navigator对象等,我们能够实现对浏览器窗口的控制、获取用户设备信息、处理页面导航等常见需求。深入理解和应用BOM,不仅有助于提升开发效率,还能够为用户提供更出色的使用体验。在今后的Web开发中,充分利用BOM的基础操作将成为编写优质、交互丰富的应用程序的重要一环。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。