原生js 之 (BOM操作)

news2024/11/21 0:37:37

BOM(浏览器对象模型)
Window对象对应着浏览器窗口本身,它的属性和方法通常被统称为BOM (浏览器对象模型)

BOM 提供了独立于内容而与浏览器窗口进行交互的对象。
BOM主要用于管理窗口与窗口之间的通讯,因此其核心对象是Window
BOM由一系列相关的对象组成,每一个对象都提供了很多方法和属性
Window是BOM的顶级对象,所有的对象都是由Window延伸出来的,BOM也可以称为window的子对象

BOM的作用

BOM提供了一组访问窗口对象的一些方法,例如:移动窗口位置,改变窗口大小,打开窗口与关闭窗口,弹出对话框,进行导航以及获取客户的一些信息,如浏览器的品牌版本,屏幕分辨率。BOM最强大的功能是它提供了一个访问HTML页面的入口:document 对象,通过document 对象入口可以使用DOM的强大功能。

Window对象
认识Window对象

Window对象是浏览器的顶级对象,它具有双重角色
Window对象是js访问浏览器窗口的一个接口
Window对象是全局对象。定义在全局作用域的变量和函数都会变成Window对象的属性和方法。

在使用Window身上的方法和属性时,因为Window对象是全局对象,所以不需要在它的属性和方法上加上前缀 Window,可直接调用它们。(Window的直接后代可不加前缀 window) 例如:alert() 、prompt() 等
除Window直接后代以外的对象,则需要在它们的前面加上前缀 window对象的名字,例如document对象是window的直接后代不需要加前缀 ,但是document对象的后代却需要document 前缀,

注意:window下有一个特殊有属性,window.name 。 此属性会在声明变量时需要注意 变量不能是name
Window对象的事件
页面(窗口)加载事件 (2种)

window.onload是窗口(页面) 加载事件,当页面内容完全加载完成后在触发该事件(包括图像,html,css文件等)就调用处理函数。

有了 window.onload就可以把 js代码写到页面元素的上方,因为window.onload是等页面的内容加载完毕再去执行处理函数。


传统的注册事件方式只能注册一次,后者会覆盖前者,而使用addEventListener则没有限制
window.onload=function(){};  //传统的注册事件方式 只能注册一个

//使用addEventListener可能注册多个事件
window.addEventListener("load",function(){});

DOMContentLoaded事件触发时,仅当DOM加载完成,不包括样式表,图片,flash等等。

只支持IE9以上 浏览器
优点:应用在图片加载较多时,交互效果不能实现,必然会影响用户的体验,此时使用DOMContentLoaded事件比较合适。

//应用在图片加载较多时,交互效果不能实现。
document.addEventListener("DOMContentLoaded",function(){
})

调整窗口大小事件

window.onresize是调整窗口大小的加载事件,当调整窗口大小时触发事件并执行处理函数。

注意:只要窗口大小发生像素变化,就会触发这个事件
经常使用 onresize 完成响应式布局。window.innerWidth 当前屏幕的宽度

    <script>
        // 注册页面加载事件
        window.addEventListener('load', function() {
            var div = document.querySelector('div');
        	// 注册调整窗口大小事件
            window.addEventListener('resize', function() {
                // window.innerWidth 获取窗口大小
                console.log('变化了');
                if (window.innerWidth <= 800) {
                    div.style.display = 'none';
                } else {
                    div.style.display = 'block';
                }
            })
        })
    </script>

UI事件
UI事件指的是哪些不一定与用户操作有关的事件,UI事件 如下表所示
在这里插入图片描述
定时器 (两种)
window.setTimeout() 一次性定时器(炸弹定时器)
window.setInterval() 循环定时器
定时器属性回调函数:普通函数是按顺序执行,而回调函数在事件触发时,回头调用处理函数。
setTimeout() 一次性定时器
setTimeout() 这是一个回调函数

window.setTimeout(调用函数,[延迟的毫秒数])

注意

window 可以省略
调用函数可以直接写函数,或者函数名
延迟的毫秒数可省略不写则为 0,如果写则,必须以毫秒
因为平时使用定时器较多,可给定时器赋值一个标识

<body>
    <img src="images/ad.jpg" alt="" class="ad">
    <script>
        // 获取要操作的元素
        var ad = document.querySelector('.ad');
		// 开启定时器
        setTimeout(function() {
            ad.style.display = 'none';
        }, 5000);
    </script>
</body>

清除 一次性定时器

window.clearTimeout(定时器的标识符)

clearTimeout ( ) 方法取消,先前通过调用 setTimeout() 建立的定时器

window可以省略

clearTimeout里面的参数是定时器的标识符。

    <button>点击停止定时器</button>
    <script>
        var btn = document.querySelector('button');
		// 开启定时器
        var timer = setTimeout(function() {
            console.log('爆炸了');
        }, 5000);
		// 给按钮注册单击事件
        btn.addEventListener('click', function() {
            // 停止定时器
            clearTimeout(timer);
        })
    </script>

setInterval()循环定时器

window.setInterval(回调函数,[间隔的毫秒数])

setInterval() 在间隔时间中重复调用函数,
可省略 window
调用函数可以直接写函数,或者函数名
延迟的毫秒数可省略不写则为 0,如果写则,必须以毫秒
第一次执行也是间隔毫秒之后执行,之后每隔毫秒数就执行一次。

<body>  
<script>
        // 1. setInterval 
        setInterval(function() {
            console.log('继续输出');
        }, 1000);
</script>
<body>

清除循环定时器

window.clearInterval(定时器的标识符) 

clearInterval()方法可取消,先前通过setInterval创建的循环定时器
window可以省略
里面的参数就是定时器的标识符
案例:倒计时
在这里插入图片描述
在这里插入图片描述

<body>   
   <div>
        <span class="hour">1</span>
        <span class="minute">2</span>
        <span class="second">3</span>
    </div>
    <script>
        // 1. 获取元素(时分秒盒子) 
        var hour = document.querySelector('.hour'); // 小时的黑色盒子
        var minute = document.querySelector('.minute'); // 分钟的黑色盒子
        var second = document.querySelector('.second'); // 秒数的黑色盒子
        var inputTime = +new Date('2019-5-1 18:00:00'); // 返回的是用户输入时间总的毫秒数

        countDown(); // 我们先调用一次这个函数,防止第一次刷新页面有空白 

        // 2. 开启定时器
        setInterval(countDown, 1000);
		
        function countDown() {
            var nowTime = +new Date(); // 返回的是当前时间总的毫秒数
            var times = (inputTime - nowTime) / 1000; // times是剩余时间总的秒数 
            var h = parseInt(times / 60 / 60 % 24); //时
            h = h < 10 ? '0' + h : h;
            hour.innerHTML = h; // 把剩余的小时给 小时黑色盒子
            var m = parseInt(times / 60 % 60); // 分
            m = m < 10 ? '0' + m : m;
            minute.innerHTML = m;
            var s = parseInt(times % 60); // 当前的秒
            s = s < 10 ? '0' + s : s;
            second.innerHTML = s;
        }
    </script>
<body>

this的指向问题

一般情况下,this指向的是函数的调用者

全局作用域或者普通函数中this指向的是全局对象window(注意定时器的this指向的是window)

在方法中调用this,谁调用this ,this指向谁

构造函数中this指向构造函数的实例

 <body>   
    <button>点击</button>
    <script>
        // this 指向问题 一般情况下this的最终指向的是那个调用它的对象
        // 1. 全局作用域或者普通函数中this指向全局对象window( 注意定时器里面的this指向window)
        console.log(this);
        function fn() {
            console.log(this);
        }
        window.fn();
        window.setTimeout(function() {
            console.log(this);
        }, 1000);
        // 2. 方法调用中谁调用this指向谁
        var o = {
            sayHi: function() {
                console.log(this); // this指向的是 o 这个对象
            }
        }
        o.sayHi();
        var btn = document.querySelector('button');
        btn.addEventListener('click', function() {
                console.log(this); // 事件处理函数中的this指向的是btn这个按钮对象
            })
        // 3. 构造函数中this指向构造函数的实例
        function Fun() {
            console.log(this); // this 指向的是fun 实例对象
        }
        var fun = new Fun();
    </script>
<body>

location对象

window对象提供了一个location属性用于获取 或设置窗体的URL,并且可以用于解析URL。因为这个属性返回的是一个对象,所以我们将这个属性也称为location对象
如果想获取文档中的URL字符串,有四种方式:

document.location;
document.location.href;
document.URL;
document.loction.toString();

解析URL地址的组成

URL:http://www.w3c.com:80/index.jsp? name=jim&when=2021#first
解析:protocol://hostname:port/pathname ? search #hash

在这里插入图片描述
location对象可以改变浏览器的历史

location.assign(url) 跟window.href与window.location 效果一样
location.replace( url ) 替换当前页面 不能 单击前进和后退按钮 跳转页面
location.reload( force ) 重新加载页面 force为 true 时从服务器重载,force为false则从缓存中重载。

在这里插入图片描述

<body>   
   <button>点击</button>
    <script>
        var btn = document.querySelector('button');
        btn.addEventListener('click', function() {
            // 记录浏览历史,所以可以实现后退功能
            location.assign('http://www.itcast.cn');
            // 不记录浏览历史,所以不可以实现后退功能
            location.replace('http://www.itcast.cn');
            //重新加载页面,相当于单击刷新按钮
            location.reload(true);
        })
    </script>
<body>

history对象 (前进与后退)
window对象提供的 history 对象 ,与浏览器历史记录进行交互。
在这里插入图片描述
history.length=0 可以确定用户是否一开始就打开了某个页面

history对象一般在实际开发中比较少用,但是会在一些OA办公系统中见到。

if(history.length==0){
  //这是用户打开窗口后的第一个页面
}

screen对象(客户端屏幕信息)
screen对象包含有关客户端显示屏幕的信息,例如显示器的尺寸大小,颜色、位置等。

screenc对象具体支持的属性会随着浏览器及其版本的改变而发生变化。不过screen对象至少能支持如下属性。
在这里插入图片描述
navigator对象 (浏览器的相关信息)
通过navigator对象 可以检查操作系统、浏览器、安全策略、语言以及是否用cookie。
注意

navigator数据可被浏览器使用者更改
一些浏览器对测试站点会识别错误。
浏览器无法报告晚于浏览器发布的新操作系统。

下面前端代码可以判断用户打开的是哪个端的页面,实现跳转。

<script>
if((navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i))) {
    window.location.href = "";     //手机
 } else {
    window.location.href = "";     //电脑
 }
<script>

JS是单线程
javaScript语言的最大特点就是单线程,也就是同一时间只能做一件事。比如在操作DOM元素进行添加和删除操作,不能同时进行。应该先进行添加,之后再删除。

单线程就意味着,所有任务需要排队,前一个任务结束,才会执行后一个任务。如果前一个任务执行耗时很长,后一个任务就不得不一直等着。
  这样所导致的问题是:如果 JS执行时间过长,这样就会造成页面的渲染不连贯,导致页面加载阻塞的感觉

同步任务与异步任务
单线程导致的问题就是后面的任务需要等待前面任务的完成。为了解决这一问题HTML5 提出web Worker标准,允许javaScript脚本创建多个线程,但是子线程完全受主线程控制。于是,js中出现了同步任务和异步任务。
同步任务

前一个任务完成后再执行后一个任务,程序的执行顺序与任务的排列顺序是一致的。
同步任务都是在主线程上执行,形成一个执行栈

异步任务

异步当执行一件耗时较长的任务时,可同时处理其他任务。
js的异步是通过回调函数实现的一般异步有三种类型。

普通事件:如 click,resize等
定时器:setlnterval、setTimeout等
资源加载: 如 load 、error等

异步任务相关回调函数添加到任务队列中(任务队列也称为消息队列 )

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

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

相关文章

Spark DAG及内存迭代计算

文章目录DAGJob与Action之间的关系DAG和分区DAG宽窄依赖DAG宽窄依赖的划分Spark内存迭代计算总结Spark是怎么做内存计算的&#xff1f;DAG的作用&#xff1f;Stage阶段划分作用&#xff1f;Spark为什么比MapReduce快&#xff1f;DAG Spark的核心是根据RDD来实现的&#xff0c;…

cubemx stm32 lu90614模块 人体温度检测模块 可以替代温枪 驱动代码

lu90614 使用串口通信在&#xff0c;指值得注意的是&#xff0c;他的TX接单片机的TX&#xff0c;RX接单片机的RX&#xff0c;和其他的串口设备不一样。 模式切换包 lu90614有两种模式&#xff0c; 一个是物温模式&#xff0c;一个是体温模式&#xff08;检测人体温度用体温…

【CSDN 竞赛—第10期】所有题目解法的思考和总结

目录 一、 熊孩子拜访 二、 走楼梯 三、括号上色 四、喜水青蛙 一、 熊孩子拜访 已知存在一个长度为n的整数序列A。 A中所有元素按照从小到达的顺序进行排序。 现在执行操作倒置一段序列。 请找到A序列里的倒置子序列。 我的解题思路&#xff08;通过所有测试用例&#xff0…

[附源码]java毕业设计星期八酒店管理系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Opengl ES之PBO

叨叨一句几句 关于Opengl的系列已经有较长的一段时间没有更新了&#xff0c;然而这个系列还远没有到完毕地步&#xff0c;后续至少还有关于Opengl矩阵变换、YUV与RGB互转、Opengl水印贴图、Opengl转场动画等主题文章。 断更的主要原因如果给自己找个借口的话可以说是工作比价…

1100w播放、45w涨粉!黑马UP在B站20天逆袭登顶!

在B站生活区里&#xff0c;“搞笑区”的流量独占鳌头&#xff0c;创作者也是络绎不绝。 为此&#xff0c;B站官方对搞笑内容创作布局了长期的扶持计划&#xff0c;比较热门的两个活动“搞笑新星训练营”、“搞笑研究所”是搞笑内容投稿最多的&#xff0c;至今两个活动已经分别…

动手实践丨基于ModelAtrs使用A2C算法制作登月器着陆小游戏

摘要&#xff1a;在本案例中&#xff0c;我们将展示如何基于A2C算法&#xff0c;训练一个LunarLander小游戏。本文分享自华为云社区《使用A2C算法控制登月器着陆》&#xff0c;作者&#xff1a;HWCloudAI 。 LunarLander是一款控制类的小游戏&#xff0c;也是强化学习中常用的…

C# dll代码混淆加密

目录 一、需求 二、用法 1.新建C#项目 2.开始加密 3.常见的错误 4.添加加密规则 5.导出加密dll 6.调用加密dll 结束 一、需求 C# 项目生成 dll&#xff0c;在反编译工具下&#xff0c;好比皇帝的新装&#xff0c;dll 内部的代码看的一清二楚&#xff0c;在这里推荐一…

关于Cy5.5 alkyne,Cyanine7 alkyne和1628790-37-3,1998119-13-3两者的区别

外观以及性质&#xff1a; Cy5.5 alkyne和Cy7alkyne 都含有荧光基团&#xff0c;其中氰基7的炔烃衍生物&#xff0c;近红外荧光团&#xff0c;Cy7的类似物&#xff0c;Cyanine5.5 alkyne用于点击化学标记的远红外/近红外染料炔烃&#xff0c;炔烃可以通过铜催化的点击化学与多种…

Ubuntu 22.04 一次及其繁琐的 允许 Traceroute 探测漏洞修复之旅

前言&#xff1a;允许 Traceroute 探测是绿盟漏洞扫描器报出来的一个漏洞&#xff0c;如下图&#xff1a; 我的系统是ubuntu 22.04&#xff0c;但由于是用户提供的虚拟机&#xff0c;会有些定制的部分&#xff0c;具体定制了哪部分就不知道了&#xff0c;直接描述问题。 解决问…

【服务器数据恢复】LINUX误删除、误格式化的数据恢复

Linux误删除及误格式化的数据恢复方案针对的文件系统&#xff1a; 1 、基于EXT2/EXT3/EXT4文件系统 &#xff1b; 2 、基于Reiserfs文件系统&#xff1b; 3 、基于Xfs文件系统。 Linux误删除及误格式化的数据恢复解决方案&#xff1a; 一、故障检测&#xff1a; 1、检测是否存在…

java学习day56(Spring Boot)Spring Boot

主要内容&#xff1a; 1.Spring Boot基本应用 2.Spring Boot原理深入及源码剖析 3.Spring Boot数据访问 4.Spring Boot视图技术 5.Spring Boot实战演练 6.Spring Boot项目部署 1. SpringBoot基本应用 1.1 约定优于配置Build Anything with Spring Boot&#xff1a;Spring Boot …

【数据结构】堆的实现及排序

目录一、树的相关概念及其特殊二叉树1、数的相关概念2、特殊二叉树二、堆1、堆的实现1.1、堆向下调整算法和向上调整算法的时间复杂度1.2、堆的构建1.3、堆的插入1.4、堆的删除1.5、取堆顶的数据、堆的个数及堆的判空2、堆的排序一、树的相关概念及其特殊二叉树 讲堆之前&#…

透视虎牙斗鱼三季报:游戏直播在各自“求变”中见分晓

游戏直播行业&#xff0c;依然硝烟弥漫。 经历千播大战、熊猫出局的洗礼后&#xff0c;虎牙和斗鱼双方缠斗升级&#xff0c;另有B站和抖音、快手等视频平台来势汹汹&#xff0c;抢夺仅有的市场蛋糕。 而在游戏行业遇冷、政策趋严等因素多重考验下&#xff0c;这场争夺战无疑将…

fsync

由于目前操作系统都具有延迟写(delayed write)功能&#xff0c; fwrite/write并不会直接把数据写到磁盘上&#xff0c; 而是在buffer满时才开始写入到磁盘。 要想把数据写到磁盘上&#xff0c;需要调用fsync函数 open(fd) write(fd) fsync(fd) close(fd) 或者 fopen(fp…

金仓数据库KingbaseES查询计划剖析

目录 1、KingbaseES数据库中的查询生命周期 2、数据设置 3、KingbaseES解释一个查询 4、什么是数据库中的缓冲区和缓存&#xff1f; 5、VERBOSE 命令参数 6、KingbaseES中的 FORMAT 解释 7、总结EXPLAIN使用方式 8、执行计划查看 了解KingbaseES查询计划对于开发人员和…

HarmonyOS应用API手势方法-绑定手势方法

述&#xff1a;为组件绑定不同类型的手势事件&#xff0c;并设置事件的响应方法。 Api&#xff1a;从API Version 7开始支持 一、绑定手势识别&#xff1a; 通过如下属性给组件绑定手势识别&#xff0c;手势识别成功后可以通过事件回调通知组件。 名称参数类型默认值描述ge…

银河麒麟V10+达梦数据库8保姆级安装教程

银河麒麟V10达梦数据库8保姆级安装教程 一、系统和数据库的下载 银河麒麟V10版本&#xff1a; 首页 → 桌面操作系统 → 银河麒麟桌面操作系统V10 → 试用&#xff08;填写信息&#xff09; → 点击地址进行下载&#xff08;X86centos7&#xff09; #如果不想进行上面的操作,…

Casbin——Java版本(笔记)

文章目录一、Casbin 是什么&#xff1f;二、快速开始2.1 载入配置2.2 如何判断权限2.3 model.conf2.3.1 基本格式2.3.2 SpringBoot下的使用2.3.3 匹配的函数内置函数自定义函数2.3.4 基于角色的访问控制角色的层次区分用户和角色隐式角色权限域内RBAC角色与函数2.3.5 优先级模型…

react事件系统(老版本)

带着问题阅读探索 React 为什么有自己的事件系统&#xff1f;什么是事件合成 &#xff1f;如何实现的批量更新&#xff1f;事件系统如何模拟冒泡和捕获阶段&#xff1f;如何通过 dom 元素找到与之匹配的fiber&#xff1f;为什么不能用 return false 来阻止事件的默认行为&…