js的Bom操作

news2025/1/7 6:41:17

1.认识Bom

◼ BOM:浏览器对象模型(Browser Object Model)
 简称 BOM,由浏览器提供的用于处理文档(document)之外的所有内容的其他对象;
 比如navigator、location、history等对象;
◼ JavaScript有一个非常重要的运行环境就是浏览器
 而且浏览器本身又作为一个应用程序需要对其本身进行操作;
 所以通常浏览器会有对应的对象模型(BOM,Browser Object Model);
 我们可以将BOM看成是连接JavaScript脚本与浏览器窗口的桥梁;
◼ BOM主要包括一下的对象模型:
 window:包括全局属性、方法,控制浏览器窗口相关的属性、方法;
 location:浏览器连接到的对象的位置(URL);
 history:操作浏览器的历史;
 navigator:用户代理(浏览器)的状态和标识(很少用到);
 screen:屏幕窗口信息(很少用到);
认识BOM

2.全局对象window

window对象

window对象在浏览器中可以从两个视角来看待:
 视角一:全局对象。
✓ 我们知道ECMAScript其实是有一个全局对象的,这个全局对象在Node中是global;
✓ 在浏览器中就是window对象;
 视角二:浏览器窗口对象。
✓ 作为浏览器窗口时,提供了对浏览器操作的相关的API;
◼ 当然,这两个视角存在大量重叠的地方,所以不需要刻意去区分它们:
 事实上对于浏览器和Node中全局对象名称不一样的情况,目前已经指定了对应的标准,称之为globalThis,并且大多数现代浏览器都支持它;
 放在window对象上的所有属性都可以被访问;
 使用var定义的变量会被添加到window对象中;
 window默认给我们提供了全局的函数和类:setTimeout、Math、Date、Object等;

window对象的作用

◼ 事实上window对象上肩负的重担是非常大的:
 第一:包含大量的属性,localStorage、console、location、history、screenX、scrollX等等(大概60+个属性);
 第二:包含大量的方法,alert、close、scrollTo、open等等(大概40+个方法);
 第三:包含大量的事件,focus、blur、load、hashchange等等(大概30+个事件);
 第四:包含从EventTarget继承过来的方法,addEventListener、removeEventListener、dispatchEvent方法;
◼ 那么这些大量的属性、方法、事件在哪里查看呢?
 MDN文档:window对象的属性、方法、事件
◼ 查看MDN文档时,我们会发现有很多不同的符号,这里我解释一下是什么意思:
 删除符号:表示这个API已经废弃,不推荐继续使用了;
 点踩符号:表示这个API不属于W3C规范,某些浏览器有实现(所以兼容性的问题);
 实验符号:该API是实验性特性,以后可能会修改,并且存在兼容性问题;

window常见属性

window常见方法

    // 2.补充的方法
    var openBtnEl = document.querySelector("button")
    var closeBtnEl = document.querySelector(".close")
    openBtnEl.onclick = function() {
      window.open("./page/new.html", "_blank")
    }
    closeBtnEl.onclick = function() {
      window.close()
    }

但是close()不是任何网页都能关闭的!应用场景有限 ,只能关闭open打开的网页

window常见事件

    // 3.常见的事件
     window.onfocus = function() {
       console.log("窗口获取到焦点")
     }
     window.onblur = function() {
       console.log("窗口失去了焦点")
     }
 
    window.onhashchange = function() {
      console.log("hash值发生改变")
    }

3.location对象

location对象常见的属性

◼ location对象用于表示window上当前链接到的URL信息。
◼ 常见的属性有哪些呢?
 href: 当前window对应的超链接URL, 整个URL;
 protocol: 当前的协议;
 host: 主机地址;
 hostname: 主机地址(不带端口);
 port: 端口;
 pathname: 路径;
 search: 查询字符串;
 hash: 哈希值;
 username:URL中的username(很多浏览器已经禁用);
 password:URL中的password(很多浏览器已经禁用);

    // 1.完整的URL
    console.log(location.href)
    // 2.获取URL信息
    console.log(location.hostname)
    console.log(location.host)
    console.log(location.protocol)
    console.log(location.port)
    console.log(location.pathname)
    console.log(location.search)
    console.log(location.hash)

 location对象常见的方法

◼ location有如下常用的方法:
 assign:赋值一个新的URL,并且跳转到该URL中;(可返回到原来网页)
 replace:打开一个新的URL,并且跳转到该URL中(不同的是不会在浏览记录中留下之前的记录);(不可返回到原来网页)
 reload:重新加载页面,可以传入一个Boolean类型;

URLSearchParams

◼URLSearchParams 定义了一些实用的方法来处理 URL 的查询字符串。
 可以将一个字符串转化成URLSearchParams类型;
 也可以将一个URLSearchParams类型转成字符串;
◼ URLSearchParams常见的方法有如下:
 get:获取搜索参数的值;
 set:设置一个搜索参数和值;
 append:追加一个搜索参数和值;
 has:判断是否有某个搜索参数;
 https://developer.mozilla.org/zh-CN/docs/Web/API/URLSearchParams
◼ 中文会使用encodeURIComponent和decodeURIComponent进行编码和解码

每个中文对应三个"%xx"

    // 4.URLSearchParams
    var urlSearchString = "?name=why&age=18&height=1.88"
    var searchParams = new URLSearchParams(urlSearchString)
    console.log(searchParams.get("name"))
    console.log(searchParams.get("age"))
    console.log(searchParams.get("height"))
 
    searchParams.append("address", "广州市")
    console.log(searchParams.get("address"))
    console.log(searchParams.toString())

4.history对象

◼ history对象允许我们访问浏览器曾经的会话历史记录。
◼ 有两个属性:
 length:会话中的记录条数;
 state:当前保留的状态值;
◼ 有五个方法:
 back():返回上一页,等价于history.go(-1);
 forward():前进下一页,等价于history.go(1);
 go():加载历史中的某一页;
 pushState():打开一个指定的地址;
 replaceState():打开一个新的地址,并且使用replace;
◼ history和hash目前是vue、react等框架实现路由的底层原理

5.navigator与screen(很少用到)

navigator 对象表示用户代理的状态和标识等信息。

    console.log(navigator.userAgent)
    console.log(navigator.vendor)
    console.log(navigator.platform)
    console.log(navigator.oscpu)
 

◼ screen主要记录的是浏览器窗口外面的客户端显示器的信息:
 比如屏幕的逻辑像素 screen.width、screen.height;

    console.log(screen.width, screen.height)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/602671.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

YOLOv5改进系列(6)——替换主干网络之 ShuffleNetV2

【YOLOv5改进系列】前期回顾: YOLOv5改进系列(0)——重要性能指标与训练结果评价及分析 YOLOv5改进系列(1)——添加SE注意力机制

预约直播|揭秘鸿蒙全新流量阵地,元服务带来的体验变革

【导读】 在PC 互联网到移动互联网的演进过程,随着人们对交互和信息获取的智能化要求越来越高,移动终端上的应用生态发展到今天也面临着变革。传统厚重的App,功能齐全,但开发成本高、周期长,且存在搜索、安装、卸载等…

Mybatis-Plus实战

文章目录 #简介#特性#支持数据库总结1、Mybatis-Plus常用注解2、[条件构造器](https://www.baomidou.com/pages/10c804/#abstractwrapper)2.1 介绍2.2 条件 3、Mybatis-Plus属性配置3.1 Mybatis-Plus常用配置项3.2 mybatis-plus.configuration. 下配置项3.3 配置小结 4、CRUD实…

javascript基础十四:解释下什么是事件代理?应用场景?

一、是什么 事件代理,俗地来讲,就是把一个元素响应事件(click、keydown…)的函数委托到另一个元素 前面讲到,事件流的都会经过三个阶段:捕获阶段 -> 目标阶段 -> 冒泡阶段,而事件委托就是…

MFA多因素认证:保护你的邮箱、VPN等账户免遭黑客入侵

多因素认证(MFA)是防范黑客攻击的重要防线之一。在密码被越来越容易被破解的情况下,多因素认证让你的账户更加安全。本文将详细讲解多因素认证是什么、如何工作以及如何设置多因素认证来保护你的账户。 什么是MFA多因素认证 简单地说&#xf…

AIGC+开放式社交,为年轻人注入了新的“Soul”?

5月21日全国助残日,Soul App举办了一场与众不同的线上公益活动,邀请视障用户担任“见习解忧师”,诉说世界更多角落“不完美”的故事,展示人生更多可能,传递温暖与爱。 参与此次派对的“见习解忧师”都是Soul平台上充满…

OTP动态口令身份认证的多种形式

密码无处不在,但却出了名的弱。因此需要新的工具和技术来减少或减轻账户被接管(ATO)的风险。OTP动态口令身份认证的主要目的就是要确保该用户的身份足够可信。现在,最常见的方法是通过增加某种认证令牌来提供MFA多因素认证。 令牌…

Linux:日志文件分析

日志文件的分类 1内核及系统日志 由系统服务syslog统一进行管理,日志格式基本相似 2 用户日志:记录系统用户登录及退出系统的相关信息 3 程序日志;由各种应用程序独立管理的日志文件,记录格式不统一 日志文件 日志保存位置&#…

day43_crud

一、CRUD (create, read (retrieve), update, delete) 增 查 改 删 1.1 代码规范 com.qf.功能名.类名 – com.qf.model.Xxx 实体类 com.qf.util.Xxx 工具类 com.qf.servlet.XxxServlet Servlet类,主要是做接收请求作出响应 com.qf.dao.XxxDao Dao类. Data Access Obje…

hive详解(二)

2 hive的两种访问方式 2.4.1 命令行的方式 在前面的操作中,我们都是通过cli的方式访问hive的。我们可以切身的体会到,通过cli的方式访问hive的不足,如:cli太过笨重,需要hive的jar支持。 2.4.2 HiveServer2模式 1.JD…

Flutter学习二:构建第一个Flutter App

目录 1 使用vsCode创建APP项目 1.1 创建项目 1.2 调试项目 2 使用AndroidStudio创建APP项目 2.1 创建项目 2.2 调试项目 1 使用vsCode创建APP项目 1.1 创建项目 查看>命令面板,输入Flutter,点击New Project >Application,按流程创…

MySQL--事务持久化原理探究

1 引言 如果让你来实现一下 MySQL 持久化的功能,你准备如何实现?如果不考虑性能,接口完全使用同步机制实现,好像也不会出现什么问题,可是不考虑性能是不现实的,IO操作多么耗时,每次写磁盘&…

2023第五届双态IT北京用户大会 | 一起见证云原生时代的数据魅力

2023年6月9日-11日,由ITSS分会指导,ITSS数据中心运营管理组、双态IT论坛联合主办,ITSS媒体组协办的“2023第五届双态IT北京用户大会”将于北京召开。 为了能够有更多专注细分领域、内容深入的分享和探讨,每一届都会和论坛成员一起…

ReID专栏(二)多尺度设计与应用

前言 多尺度流层可以更有效地提取多尺度信息,而基于显著性的学习融合层有利于重要特征通道的自动选择,因此MuDeep在学习鉴别模式方面很强大。其实这也是目前大多数深度学习任务发表论文的趋势,即多尺度、显著性特征的表示。 本教程禁止转载。…

OpenMMLab AI实战营第二期(2)MMPose初体验

根据MMPose的官方文档学习一下 MMPose文档地址:https://mmpose.readthedocs.io/zh_CN/latest/index.html 文章目录 1. 概述2. 安装2.1 创建conda环境并激活2.2 安装pytorch2.3 使用 MIM 安装 MMEngine 和 MMCV2.4 安装MMPose 3. 20 分钟了解 MMPose 架构设计3.1 总…

Typora导出pdf一直停留在导出界面

Typora导出pdf一直停留在导出界面 1. 因为修改临时文件夹地址导致的问题 尝试遍了网上的各种方法对我都没奏效。 但是用管理员权限在 C:\Program Files\Typora 下打开 typora.exe 发现可以正常导出 pdf。 结合这一点,加上最近频繁出现启动文件、文件夹没有权限的…

ES查询 too_many_clauses,maxClauseCount is set to 5000

一:语法执行背景 ES boo查询中过多的拼接bool导致报maxClauseCount is set to 5000 { "caused_by": { "type": "too_many_clauses","reason": "maxClauseCount is set to 5000" } } 查询DSL语句: { …

问题解决:微信开发者工具显示清除登录状态失败 TypeError: Failed to fetch [1.06.2303220][win32-x64]

问题: 在编译之前,会进行清除全部缓存操作,但是点击后出现清除清除登录状态失败。 清除登录状态失败 TypeError: Failed to fetch [1.06.2303220][win32-x64]原因: 未连接网络,或者被你连接的网络拦截。 解决&#xf…

基于 PaddleVideo 的花滑骨骼点动作识别 2s-AGCN

配置文件节点流配置文件 2s-agcn_ntucs_joint_fsd.yamlMODEL 字段DATASET 字段PIPELINE 和 INFERENCE 字段OPTIMIZER 字段 agcn2s.pygraph输入通道数 骨骼流 Dataset 和 Pipeline配置文件DATASETPIPELINE 源码skeleton.pyskeleton_pipeline.pyAutoPaddingSkeletonNormIdenSkete…

springboot+vue高校学科建设资源管理系统

本 1、数据库的构建:数据库需求分析根据所需要实现的功能,对其数据库的需求进行分析。 2、后台管理:网站后台是给管理员用作管理网站内容的操作界面,它是网站日常维护,网站内容操作的交互窗口,是完成网站后…