JS4-BOM浏览器对象类型
什么是BOM
浏览器的顶级对象
页面加载事件以及注意事项
定时器函数
JS执行机制
页面跳转、刷新
history、navigator对象
什么是BOM
浏览器对象模型(Browser Object Model),主要作用是提供独立于内容而与浏览器窗口进行交互的对象,核心是window,BOM缺乏标准
对比
DOM BOM
文档对象模型 浏览器对象模型
顶级对象的document 顶级对象是window
主要学习操作元素 主要和浏览器窗口交互,刷新跳转等
W3C BOM是浏览器厂商各自定义的,兼容性差
BOM的构成
window对象是浏览器的顶级对象,具有双重角色
- 是JS访问浏览器窗口的一个接口
- 是一个全局对象,定义在全局作用域中的变量、函数都会变成window对象的方法和属性
- 在调用的时候可以省略window,前面学习的对话框alert()、prompt()等
- window下不要直接定义变量为name,因为有个特殊属性window.name
window对象常见事件
窗口加载事件
window.onload=function(){}
window.addEventListener=("load",function(){})
window.onload是窗口加载事件,当文档enrich完全加载完成会触发该事件(包括图像、脚本文件、CSS文件等),就调用的处理函数
- 有了window.onload就可以把JS代码写到页面元素的上方,但是写了多个后只处理最后一个
- 如果用addEventListener则没有限制
document.addEventListener('DOMContentLoaded',function(){})
仅当DOM加载完成时才会触发,不包含样式表、图片、flash等,ie9以上才支持
在页面图片很多加载很慢的时候,可以提前获取交互,保证用户体验
调整窗口大小事件
window.onresize=function(){}
window.addEventListener=("resize",function(){})
调整窗口大小事件
- 只要窗口带下发生像素变化时,就会触发
- 用于响应式布局;window.innerWidth可以获得屏幕宽度
var div = document.querySelector('div');
window.addEventListener('resize', function () {
if (window.innerWidth <= 800) {
div.style.display = 'none';
} else {
div.style.display = 'block';
}
})
定时器
两种定时器
setTimeOut()
window.setTimeout(调用函数,[延迟的毫秒数]);
- 延迟时间可以省略
- 调用函数可以直接写函数,还可以写函数名
- 还有一个写法'函数名()',不提倡
- 页面中可能有很多定时器,我们经常给定时器加标识符
function callback() {
console.log('111');
}
var time1 = setTimeout(callback, 3000);
var time2 = setTimeout(callback, 1000);
回调函数callback:需要等待时间,时间到了才去调用这个函数以前的.onclick=function()里面的函数也是回调函数
案例:5s后自动隐藏广告
var ad = document.querySelector('.ad');
setTimeout(function () {
ad.style.display = 'none';
}, 5000)
计时器停止:
window.clearTimeout(timeoutID)
setInterval()定时器
window.setInterval(回调函数,[间隔的毫秒数])
执行过程不同,本函数是每间隔一定时间就执行一次,会不断执行,setTimeout只执行一次
案例:秒杀倒计时
- 这个倒计时是不断变化的 ,因此需要定时器来自动变化(setInterval)
- 三个盒子分别存放时分秒
- 三个黑色盒子利用innerHTML放入计算的小时分钟秒数
- 最好先调用一次函数,防止刚刷新页面时出现空白
var hour = document.querySelector('.hour');
var minute = document.querySelector('.minute');
var second = document.querySelector('.second');
var inputTime = +new Date('2021-3-13 18:00:00');//用户想输入的时间
countDown();//最好先调用一次函数,防止刚刷新页面时出现空白
//开启定时器 每秒都调用该函数
setInterval(countDown, 1000);
function countDown(time) {
var nowTime = +new Date();//当前时间总的毫秒数
var times = (inputTime - nowTime) / 1000;//秒数
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;
}
window.clearInterval();停止定时器
- 有时外界需要内部的变量,需要在函数外定义对象,可以定义为null
this
指向调用它的对象
全局作用域下或者普通函数下this指向window;(定时器里面的this指向window)
方法调用中this指向的是调用它的对象
btn.addEventListener('click',function(){})
btn.onclick=function(){};
//都指向btn
- 构造函数中this指向构造函数的实例
var fun=new Fun();//this指向fun
JS执行队列
JS单线程
JS是单线程语言,同一时间只能做一件事。
单线程意味着所有任务需要排队,如果JS执行事件过长,会造成其他代码等待时间过长
为了解决这个问题,HTM5提出了Web Worker标准,允许JS创建多个线程,因此出现了同步和异步
同步和异步
同步:
前一个任务结束后再执行后一个任务,程序的执行顺序和任务的排列顺序是一致的、同步的
异步:
做一件事情的时候同时还可以做其他事情
本质区别:这条流水线上各个流程执行顺序不同
同步任务:同步任务都在主线程上进行,行程一个执行栈
异步任务:JS的异步是通过回调函数实现的,
- 普通事件:如click、resize等
- 资源加载,如load、error等
- 定时器,如setinterval、setTimeout等
异步任务相关回调函数添加到任务队列(消息队列)中。
JS执行机制
- 先执行执行栈中同步任务
- 异步任务放入任务队列中
- 一旦执行栈中所有同步任务执行完毕,系统就会按次序读取任务队列中的异步任务,于是被读取的异步任务结束等待状态,进入执行栈,开始执行
由于主线程不断的获取任务、执行任务、再获取任务、再执行任务,这种机制被称为事件循环
Location对象
window对象给我们提供了一个location属性用于获取或设置窗体的URL,并且可以用于解析URL。该属性返回的是一个对象,因此也称为Location对象
URL
统一资源定位符(Uniform Resource Locator),是互联网标准资源的地址,互联网每个文件都有位移的URL,包含的信息之处文件的位置以及浏览器该如何处理它
URL一般格式
protocol://host[:port]/path/[?query]#fragment
http://www.itcast.cn/index.html?name=andy&age=18#link
- protocol 通信协议 常用的http、ftp、maito等
- host 主机(域名)
- port 端口号 可选,省略时使用方案的默认端口,如http的默认端口为80
- path路径 由零或多个'/'符号隔开的字符串,一般用来表示主机上的一个目录或文件地址
- query 参数 以键值对的形式,用&号分割开
- fragment 片段 #后面内容,常见于连接锚点
Location对象的属性
location.href 获取或设置整个URL 可以实现点击某位置跳转其他页面
location.host 返回主机(域名)
location.port 返回端口号
location.pathname返回路径
location.search 返回参数(query)
location.hash 返回片段 #后面内容常见于链接 锚点
案例:5s后自动跳转页面
var timer=5;
setInterval(function(){
if(timer==0){
location.href='http://www.itcast.cn';
}else{
div.innerHTML='将在'+timeer+'s 后跳转首页';
timer--;}
},1000)
案例:提交表单后跳转到另一个页面并显示
- 第一个登陆页面,里有提交表单,利用action='index.html'提交到第二个页面,input表单必须有name属性,作为提交的属性
- 第二个页面,可以使用第一个页面的参数,利用了参数的传递,从location.search可以得到
- location.search得到的是形如 ?name=Andy 的样式,需要去掉问号(substr(开始的位置,位数)
- 还需要利用split('=')分开参数和值
Location常用方法
location.assign 跳转页面,记录浏览器历史,可以使用后退功能
location.replace 跳转页面,但是不记录历史,无法后退
location.reload 重新加载,相当于刷新页面,如果参数为true表示强制刷新(不读取缓存中图片,机载较慢),不填表示类似于F5直接刷新
navigator对象
navigator.userAgent显示浏览器信息、系统信息
if((navigator.userAgent.match(/(iPhone|iPod|Android|ios|iPad|hpwOS|SysbianOS|Windows Phone|UCWEB|BlackBerry|Nokia|RIM|IEMobile|Mobile)/i){
location.href="http://www.cnblogs.com/dying"}
else{
location.href="";
}
history对象
history.forward() 前进功能
history.back()后退
go() 参数是2表示前进2个页面,-2表示后退2个页面
一些OA办公系统有可能会用到
JS4-BOM浏览器对象类型的更多相关文章
- BOM浏览器对象
BOM 浏览器对象 一.浏览器本身就自己有一些对象,不用创建就可以使用 window(当前浏览器窗体) 属性: status opener closed parent top 方法: alert(); ...
- day28 BOM浏览器对象 & 定时事件与Cookie & (视频卷子讲解)
3.10 BOM浏览器对象模型 3.10.1 window对象 所有浏览器都支持window对象,它表示浏览器窗口: | 属性 | history 网页历史记录 返回History只读对象 locat ...
- BOM浏览器对象模型和API速查
什么是BOMBOM是Browser Object Model的缩写,简称浏览器对象模型BOM提供了独立于内容而与浏览器窗口进行交互的对象由于BOM主要用于管理窗口与窗口之间的通讯,因此其核心对象是wi ...
- JS BOM(浏览器对象)
BOM即浏览器对象模型,它包括如下一些对象! (一)screen对象,Screen 对象中存放着有关显示浏览器屏幕的信息. 常见的属性有: availHeight:返回显示屏幕的高度 availWid ...
- 浏览器(BOM)对象的一些内置方法总结
浏览器(BOM)对象的一些内置方法总结 一.总结 1.bom就是浏览器那端执行的代码,dom就是服务器那端操作html的代码 2.记好bom的几个对象,那就很好理解很多代码了,也很好写很多代码了 二. ...
- js中浏览器对象BOM
参考 : https://www.cnblogs.com/Peng2014/p/4725524.html 1. window对象 https://www.runoob.com/jsref/ob ...
- 6、JavaScript进阶篇③——浏览器对象、Dom对象
一.浏览器对象 1. window对象 window对象是BOM的核心,window对象指当前的浏览器窗口. window对象方法: 注意:在JavaScript基础篇中,已讲解了部分属性,windo ...
- 第一百一十一节,JavaScript,BOM浏览器对象模型
JavaScript,BOM浏览器对象模型 学习要点: 1.window对象 2.location对象 3.history对象 BOM也叫浏览器对象模型,它提供了很多对象,用于访问浏览器的功能.BOM ...
- JS BOM DOM对象 select联动 计时器 时间 css操作 节点(标签 ) 查找标签 {前端基础之BOM和DOM}
前端基础之BOM和DOM 前戏 到目前为止,我们已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些交互,我 ...
- JS框架设计之对象类型判断一种子模块
Javascript有两套数据类型,一套是基础数据类型,一套是对象数据类型.基础数据类型包括5种基本数据类型,分别是null,bool,undefined,number,string,也叫简单数据类型 ...
随机推荐
- 从零开始配置vim(21)——会话管理
很多代码编辑器都有这么一个功能,重新进入编辑器之后能恢复上次打开的所有文件,窗口布局,有的甚至是上次设置的一些配置.那么vim是否也可以实现这样的功能呢?答案是肯定的.使用vim自带的会话管理和 vi ...
- Flask 框架:实现简单API测试接口
通过使用Python中Flask框架实现一个简单的API接口程序,用户可发送JSON格式的请求,服务器响应请求,并以JSON格式将数据返回给用户,此处代码是一个模板可以测试接口时使用. Flask代码 ...
- JuiceFS 在大搜车数据平台的实践
大搜车已经搭建起比较完整的汽车产业互联网协同生态.在这一生态中,不仅涵盖了大搜车已经数字化的全国 90% 中大型二手车商.9000+ 家 4S 店和 70000+ 家新车二网,还包括大搜车旗下车易拍. ...
- 小结_第一个Java程序
总结: 1. Java程序的编写与执行: 步骤1: 编写. 在后缀名为.java的文件中编写Java代码,该文件称为源文件 步骤2: 编译. 针对后缀名为.java源文件进行编译,生成字节码文件. 格 ...
- 将实体光盘制作成光盘映像iso文件
春节假期整理历史物件时发现一些书籍的光盘,虽然买了多年但一直没有看过,因为自己在用的电脑都没有光驱.正好老爸的电脑是带光驱的,想着趁过节把这些光盘的内容读取出来存在NAS上方便后续使用. 使用Ultr ...
- 永久解决 WSL vm.max_map_count 65530 is too low 的问题
问题 在使用基于 WSL 的 Docker 的时候,启动 ES 总是会出现 vm.max_map_count 65530 is too low 问题,导致容器无法启动,网上答案基本就两种,例如 sta ...
- NC50493 石子合并
题目链接 题目 题目描述 将n堆石子绕圆形操场排放,现要将石子有序地合并成一堆.规定每次只能选相邻的两堆合并成新的一堆,并将新的一堆的石子数记做该次合并的得分. 请编写一个程序,读入堆数n及每堆的石子 ...
- linux 中grep 命令详细使用方法说明
前言在linux命令行中,经常需要对当前获取的一堆数据进行过滤.提取和分析,其中grep命令是其中非常重要的命令之一,比如,在生产环境服务器上,经常使用到下面这个命令 ps -ef | grep ja ...
- CentOS在无网络环境下,用离线源yum安装软件
先说大致步骤: 1.前提假设:当前无网络的目标服务器是A,我们需要先准备一台服务器B: 2.在B上面用yum先把软件安装完成. 3.然后用createrepo将B中的包拷贝出来,并传到A上(用U盘或者 ...
- Ubuntu在无网络环境下,用离线源apt-get安装软件
步骤概要如下: 1.假设目标安装的是服务器A,需先准备一台正常环境,且操作系统版本与A一致的服务器B: 2.用apt-get在服务器B上下载需要安装的包,并用dpkg-scanpackages依赖打包 ...