JS学习笔记8之 BOM-浏览器对象模型
*什么是BOM
-->BOM (Browser Object Model) 浏览器对象模型
-->BOM提供了独立于内容而与浏览器窗口进行交互的对象
-->BOM主要用于管理窗口与窗口之间的通讯,因此其核心对象是window
-->BOM缺乏标准,JavaScript语法的标准化组织是ECMA,DOM的标准化组织是W3C, BOM最初是Netscape浏览器标准的一部分
*BOM主要内容
-->window对象 是浏览器中的Global对象
-->窗口设置 (打开、大小、位置)
-->间歇调用与超时调用
-->对话框 (提示框、确认框、输入框)
-->location对象 (位置对象包含各种属性和方法)
-->navigator对象 用于提供用户浏览器的相关信息
-->screen对象 包含有关用户屏幕的信息
-->history对象 包含有关用户的访问历史记录
(本篇内容有些内容不常用,可以着重掌握标红标重的部分)
一、窗口设置 (打开、大小、位置)
1、打开新窗口
window.open(URL,name,specs);
URL:打开页面的URL,没有指定URL将打开新的空白窗口(默认)
name:_blank 新窗口打开(默认)
_self 当前页面打开
name 窗口名称 ......
specs:一个逗号分隔的项目列表。支持以下值:
height=pixels 窗口的高度,最小值为100
width=pixels 窗口的宽度,最小值为100
left=pixels top=pixels ......
示例 window.open('','','width=200,height=200');
2、关闭窗口
window.close() 方法用于关闭浏览器窗口
(DOM window对象的方法)
close() 方法将关闭有 window 指定的顶层浏览器窗口。某个窗口可以通过调用 self.close() 或只调用 close() 来关闭其自身。只有通过 JavaScript 代码打开的窗口才能够由 JavaScript 代码关闭。这阻止了恶意的脚本终止用户的浏览器。
3、窗口大小
设置窗口大小 window.resizeTo(width,height);
调整窗口大小 window.resizeBy(width,height);
<body>
<button id="btn1">打开新窗口</button><br>
<button id="btn2">关闭新窗口</button><br>
<button id="btn3">设置窗口大小</button><br>
<button id="btn4">调整窗口大小</button><br>
<script>
var btn1=document.getElementById('btn1');
var btn2=document.getElementById('btn2');
var btn3=document.getElementById('btn3');
var btn4=document.getElementById('btn4');
var n;
/*1、打开新窗口*/
btn1.onclick=function(){
// window.open('my1.html','','width=400,height=200,left=400,top=300');//打开具体页面不可以调整大小
n=window.open('','','width=100,height=100,left=400,top=300');//打开空白页可以调整大小
}
/*2、关闭浏览器窗口--window.close()(DOM里设置)*/
btn2.onclick=function(){
window.close();
}
/*3、调整窗口大小 ;&大小 */
//设置窗口大小;window.resizeTo(width,height);
btn3.onclick=function(){
n.resizeTo(500,500);
}
//调整窗口大小:window.resizeBy(width,height);
//把窗口大小增加或减小指定的宽度和高度。
btn4.onclick=function(){
n.resizeBy(100,-100);
}
</script>
</body>
4、窗口位置
window.screenLeft属性返回窗口相对于屏幕的X坐标
window.screenTop属性返回窗口相对于屏幕的Y坐标
window.screenX属性返回窗口相对于屏幕的X坐标
window.screenY属性返回窗口相对于屏幕的Y坐标
5、窗口可视区尺寸
document.documentElement.clientWidth
document.body.clientWidth
document.documentElement.clientHeight
document.body.clientHeight
<body>
<button id="btn">获取</button>
<h3 id="con1"></h3>
<h3 id="con2"></h3>
<h3 id="con3"></h3>
<h3 id="con4"></h3>
</body>
<script>
btn.onclick=function(){
con1.innerHTML='窗口相对于屏幕的X坐标:'+window.screenLeft+'窗口相对于屏幕的Y坐标:'+window.screenTop;
con2.innerHTML='窗口相对于屏幕的X坐标:'+window.screenX+'窗口相对于屏幕的Y坐标:'+window.screenY;
con3.innerHTML='窗口可视区宽度'+document.documentElement.clientWidth+'窗口可视区高度'+document.documentElement.clientHeight;
con4.innerHTML='文档宽度'+document.documentElement.offsetWidth+'文档高度'+document.documentElement.offsetHeight;
}
</script>
6、窗口垂直滚动条
document.body.scrollTop(无文档声明)
document.documentElement.scrollTop
二、BOM计时器
1、间歇调用
setInterval ( 函数/名称 , 毫秒数 )
表示每经过一定的毫秒后,执行一次相应的函数(重复)
2、超时调用
setTimeout ( 函数/名称 , 毫秒数 )
表示经过一定的毫秒后,只执行一次相应的函数(不重复)
清除计时器:clearInterval( ); clearTimeout( );
三、BOM对话框
1、提示框 alert (“ ”);
用户必须先关闭该消息框然后才能继续进行操作
2、确认框 confirm(“ ”);
confirm(“需要确认的内容”);
选择“确定”返回true 选择“取消”返回false
3、输入框 prompt(“ ”,“ ”);
prompt(“对话框中显示的文本”,"默认的输入文本");
单击取消按钮,则返回 null
单击确认按钮,则返回输入的文本
<body>
<button id="btn">弹窗</button>
<h1 id="con"></h1>
<script>
/*提示框 alert (“ ”);*/
//用户必须先关闭该消息框然后才能继续进行操作
btn.onclick=function(){
alert('我只是一个alert弹框!');
}
/*确认框 confirm(“需要确认的内容”);*/
//选择“确定”返回true 选择“取消”返回false
var bool=confirm('你喜欢喽喽吗');
if (bool) {
console.log(bool);
con.innerHTML='喽喽爱你';
} else {
console.log(bool);
con.innerHTML='好幼稚啊!';
}
/*输入框 prompt(“对话框中显示的文本”,"默认的输入文本");*/
//单击取消按钮,则返回 null
//单击确认按钮,则返回输入的文本
var value=prompt('喽喽的小名叫什么','')
if(value==null){
console.log(value);
alert('对不起,您无权访问1');
}else{
if(value=='小仙女'){
console.log(value);
alert('恭喜,访问成功1');
window.open('my1.html','','');//访问成功,打开新的窗口
}else{
console.log(value);
alert('输入验证信息错误,请重新输入!');
}
}
</script>
</body>
四、location对象
location对象 包含有关当前页面的URL信息
属性:
host 设置或返回主机名和当前 URL 的端口号。
port 设置或返回当前 URL 的端口号。
href 设置或返回完整的 URL。 ……
方法:三条语句分开使用
assign() 加载新的文档。
reload() 重新加载当前文档。
replace() 用新的文档替换当前文档。
<body>
<button id="btn">返回完整的 URL</button>
<button id="btn1">加载新的文档assign()</button>
<button id="btn2">重新加载当前文档reload()</button>
<button id="btn3">用新的文档替换当前文档replace()</button>
<h1 id="con"></h1>
<script>
var x=0;
setInterval(function(){
x++;
con.innerHTML=x;
},1000)
btn.onclick=function(){
//href:返回完整的 URL。
con.innerHTML=location.href;
//href 设置完整的 URL
//location.href='my1.html';
}
btn1.onclick=function(){
//assign() 加载新的文档
location.assign('https://www.baidu.com/');
}
btn2.onclick=function(){
//reload() 重新加载当前文档
location.reload();
}
btn3.onclick=function(){
//replace() 用新的文档替换当前文档
location.replace('https://www.taobao.com/');
}
</script>
</body>
五、navigator对象
1、navigator对象部分属性
appCodeName 返回浏览器的代码名。
appName 返回浏览器的名称。
cookieEnabled 返回指明浏览器中是否启用cookie的布尔值。
platform 返回运行浏览器的操作系统平台。
appVersion 返回浏览器的平台和版本信息。
userAgent 返回由客户机发送服务器的user-agent头部的值。用户代理
<body>
<h4 id="con1"></h4>
<h4 id="con2"></h4>
<h4 id="con3"></h4>
<h4 id="con4"></h4>
<h4 id="con5"></h4>
<h4 id="con6"></h4>
<script>
con1.innerHTML='浏览器的代码名:'+navigator.appCodeName;
con2.innerHTML='浏览器的名称:'+navigator.appName;
con3.innerHTML='返回指明浏览器中是否启用cookie的布尔值:'+navigator.cookieEnabled;
con4.innerHTML='运行浏览器的操作系统平台:'+navigator.platform;
con5.innerHTML='浏览器的平台和版本信息:'+navigator.appVersion;
con6.innerHTML='用户代理:由客户机发送服务器的user-agent头部的值:'+navigator.userAgent;
</script>
</body>
2、用户浏览器识别码
var str=window.navigator.userAgent;
var str=window.navigator.appVersion;
alert(str);
3、大小写转换
str.toLowerCase( ); 转换成小写
str.toUpperCase( ); 转换成大写
实例:用浏览器识别码和大小写转换-->判断浏览器
<script>
var str=window.navigator.userAgent.toLowerCase();//获取用户浏览器识别码并转换成小写
if (str.indexOf('chrome')!=-1) {
alert('是谷歌浏览器');
}else if(str.indexOf('firefox')!=-1){
alert('是火狐浏览器');
}else if(str.indexOf('msie')!=-1){
alert('是IE8浏览器');
};
</script>
六、indexOf()方法
定义和用法
indexOf( )方法 可返回某个指定的字符串值在字符串中首次出现的位置
语法:string.indexOf(str,index);
参数:str-------规定需检索的字符串值
index----规定在字符串中开始检索的位置
注意:indexOf( ) 方法对大小写敏感
如果要检索的字符串值没有出现,则该方法返回 -1
<script>
var str='abcdefcghijk';
alert(str.indexOf('c'));//
alert(str.indexOf('c',3));//
alert(str.indexOf('A'));//-1
</script>
七、screen对象
screen 对象包含有关客户端显示屏幕的信息
width 返回显示器屏幕的宽度。
height 返回显示器屏幕的高度。
availHeight 返回显示屏幕的高度 (除 Windows 任务栏之外)。
availWidth 返回显示屏幕的宽度 (除 Windows 任务栏之外)。
八、history对象
history 对象包含用户在浏览器中访问过的URL
length 返回浏览器历史列表中的 URL 数量。
back() 加载 history 列表中的前一个 URL。
forward() 加载 history 列表中的下一个 URL。
go() 加载 history 列表中的某个具体页面。
history.go(-1) 后退一页
history.go(1) 前进一页
实例:(关于付款成功后返回到上一页的设置)
BOM计时器_history_付款1.html
<body>
<h1>付款页面</h1>
<a href="BOM计时器_history_付款2.html">付款</a>
</body>
BOM计时器_history_付款2.html
<body>
<h1>恭喜!付款成功!</h1>
<button id="btn">返回上一页</button>
<span><var id="num">5</var>后自动返回上一页!</span>
<script>
var btn=document.getElementById('btn');
var num=document.getElementById('num');
var timer=null,x=5;
btn.onclick=function(){
window.history.go(-1);
}
timer=setInterval(function(){
x--;
if (x<=0) {
window.history.go(-1);
}
num.innerHTML=x;
},1000)
</script>
</body>
JS学习笔记8之 BOM-浏览器对象模型的更多相关文章
- JavaScript高级程序设计(第3版)学习笔记·第8章——浏览器对象模型BOM
转自:http://www.shaoqun.com/a/43768.aspx 访问和操作浏览器窗口的模型称为浏览器对象模型BOM(Browser Object Model),但习惯上是把所有针对浏览器 ...
- 【学习笔记】八:浏览器对象模型BOM
1.window对象 window是BOM的核心,它既是JS访问浏览器的一个接口,又是ES规定的Global对象. 1)全局作用域对象 a.所有在全局作用域中声明的变量.函数都会成为window对象的 ...
- JS学习笔记5_DOM
1.DOM节点的常用属性(所有节点都支持) nodeType:元素1,属性2,文本3 nodeName:元素标签名的大写形式 nodeValue:元素节点为null,文本节点为文本内容,属性节点为属性 ...
- Node.js学习笔记(1):Node.js快速开始
Node.js学习笔记(1):Node.js快速开始 Node.js的安装 下载 官方网址:https://nodejs.org/en/ 说明: 在Windows上安装时务必选择全部组件,包括勾选Ad ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- VSTO学习笔记(二)Excel对象模型
原文:VSTO学习笔记(二)Excel对象模型 上一次主要学习了VSTO的发展历史及其历代版本的新特性,概述了VSTO对开发人员的帮助和效率提升.从这次开始,将从VSTO 4.0开始,逐一探讨VSTO ...
- 第一百一十一节,JavaScript,BOM浏览器对象模型
JavaScript,BOM浏览器对象模型 学习要点: 1.window对象 2.location对象 3.history对象 BOM也叫浏览器对象模型,它提供了很多对象,用于访问浏览器的功能.BOM ...
- 一点感悟:《Node.js学习笔记》star数突破1000+
写作背景 笔者前年开始撰写的<Node.js学习笔记> github star 数突破了1000,算是个里程碑吧. 从第一次提交(2016.11.03)到现在,1年半过去了.突然有些感慨, ...
- 生命不息学习不止,前端js学习笔记(一)
引言 从毕业到年已经整整7年,期间一直从事.net开发做c/s从 c# 转到 wpf 而后又开始做b/s 用silverlight,从最开始的arcgis engine 到后来的silverlight ...
- 【转】Backbone.js学习笔记(二)细说MVC
文章转自: http://segmentfault.com/a/1190000002666658 对于初学backbone.js的同学可以先参考我这篇文章:Backbone.js学习笔记(一) Bac ...
随机推荐
- show master/slave status求根溯源
show master/slave status分别是查看主数据库以及副数据库的状态,是一种能查看主从复制运行情况的方式. 这里仅仅讨论linux下的nysql5.7.13版本的执行情况 一.show ...
- 【夔堂】:程序血泪史之——有一种垃圾语言叫做JavaScript
"Prototype"机制是个半成品OOP,有些文章说这玩意当初为了"简单(编写).容易(学习)"而发明的,但web前端技术发展到今天我们看到,JS显然是需要O ...
- Sql Server系列:字符串函数
字符串函数用于对字符和二进制字符串进行各种操作,大多数字符串函数只能作用于char.nchar.varchar和nvarchar数据类型.字符串函数可以用在SELECT或者WHERE语句中. 1. A ...
- Entity Framework Code First使用DbContext查询
DbContext.DbSet及DbQuery是Entity Framework Code First引入的3个新的类,其中DbContext用于保持数据库会话连接,实体变化跟踪及保存,DbSet用于 ...
- .NET平台开源项目速览(9)软件序列号生成组件SoftwareProtector介绍与使用
在文章:这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,给大家初步介绍了一下Software Protector序列号生成组件.今天就通过一篇简单的文章来预览一下其强大的功 ...
- java中的list时间排序
最初设想使用:时间long型 private void testTimes() throws InterruptedException{ Calendar cal=Calendar.getInstan ...
- 微信小程序小技巧系列《一》幻灯片,tab导航切换
作者:gou-tian 来自:github 幻灯片 使用微信小程序原生组件swiper实现. <swiper indicator-dots="{{indicatorDots}}&quo ...
- 将文本文件的内容存储在DataSet中的方法总结
项目中比较多的会对文件进行操作,例如文件的上传下载,文件的压缩和解压等IO操作.在.NET项目中较多的会使用DataSet,DataTable进行数据的缓存. 项目中对文本文件的操作比较简单,但是如果 ...
- 你的日志组件记录够清晰嘛?--自己开发日志组件 Logger
现在现成的日志组件实在是太多太多,为什么我还需要自己实现呢????? 需求来源于java的log4j, [07-31 16:40:00:557:WARN : com.game.engine.threa ...
- Struts2 源码分析——Action代理类的工作
章节简言 上一章笔者讲到关于如何加载配置文件里面的package元素节点信息.相信读者到这里心里面对struts2在启动的时候加载相关的信息有了一定的了解和认识.而本章将讲到关于struts2启动成功 ...