*什么是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-浏览器对象模型的更多相关文章

  1. JavaScript高级程序设计(第3版)学习笔记·第8章——浏览器对象模型BOM

    转自:http://www.shaoqun.com/a/43768.aspx 访问和操作浏览器窗口的模型称为浏览器对象模型BOM(Browser Object Model),但习惯上是把所有针对浏览器 ...

  2. 【学习笔记】八:浏览器对象模型BOM

    1.window对象 window是BOM的核心,它既是JS访问浏览器的一个接口,又是ES规定的Global对象. 1)全局作用域对象 a.所有在全局作用域中声明的变量.函数都会成为window对象的 ...

  3. JS学习笔记5_DOM

    1.DOM节点的常用属性(所有节点都支持) nodeType:元素1,属性2,文本3 nodeName:元素标签名的大写形式 nodeValue:元素节点为null,文本节点为文本内容,属性节点为属性 ...

  4. Node.js学习笔记(1):Node.js快速开始

    Node.js学习笔记(1):Node.js快速开始 Node.js的安装 下载 官方网址:https://nodejs.org/en/ 说明: 在Windows上安装时务必选择全部组件,包括勾选Ad ...

  5. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  6. VSTO学习笔记(二)Excel对象模型

    原文:VSTO学习笔记(二)Excel对象模型 上一次主要学习了VSTO的发展历史及其历代版本的新特性,概述了VSTO对开发人员的帮助和效率提升.从这次开始,将从VSTO 4.0开始,逐一探讨VSTO ...

  7. 第一百一十一节,JavaScript,BOM浏览器对象模型

    JavaScript,BOM浏览器对象模型 学习要点: 1.window对象 2.location对象 3.history对象 BOM也叫浏览器对象模型,它提供了很多对象,用于访问浏览器的功能.BOM ...

  8. 一点感悟:《Node.js学习笔记》star数突破1000+

    写作背景 笔者前年开始撰写的<Node.js学习笔记> github star 数突破了1000,算是个里程碑吧. 从第一次提交(2016.11.03)到现在,1年半过去了.突然有些感慨, ...

  9. 生命不息学习不止,前端js学习笔记(一)

    引言 从毕业到年已经整整7年,期间一直从事.net开发做c/s从 c# 转到 wpf 而后又开始做b/s 用silverlight,从最开始的arcgis engine 到后来的silverlight ...

  10. 【转】Backbone.js学习笔记(二)细说MVC

    文章转自: http://segmentfault.com/a/1190000002666658 对于初学backbone.js的同学可以先参考我这篇文章:Backbone.js学习笔记(一) Bac ...

随机推荐

  1. 重温 w3cshool css3

    border-radius: 2em 1em 4em / 0.5em 3em;  兼容性IE9+.Firefox 4+.Chrome.Safari 5+ 以及 Opera 支持 border-radi ...

  2. Javascript刷题 》 查找数组元素位置

    找出元素 item 在给定数组 arr 中的位置 输出描述: function indexOf(arr, item) { ..... } 如果数组中存在 item,则返回元素在数组中的位置,否则返回 ...

  3. ES6 - Note3:数组、对象与函数的扩展

    一.数组的扩展,ES6在数组扩展了一些API,以实现更多的功能 1.Array.from:可以将类数组和可遍历的数据结构转换成真正的数组,如下所示 var a = { '0':1,'1':1,leng ...

  4. 【记录】ASP.NET MVC MapRoute .htm 不起作用

    RegisterRoutes 注册路由示例配置: public static void RegisterRoutes(RouteCollection routes) { routes.IgnoreRo ...

  5. 程序员眼中的 SQL Server-非聚集索引能给我们带来什么?

    写在前面 最近在做的一个项目,页面访问的时候很慢(大概几秒钟的样子),然后用日志记录的方式,来排查这个问题,最后发现是 Entity Framework 初始化的一个坑(大概要花 6-7 秒),详见: ...

  6. 【记录】Install-Package : “Unity”已拥有为“CommonServiceLocator”定义的依赖项。

    在使用 NuGet 安装 Unity 的时候,安装命令:install-package unity. 但是会莫名奇妙的报如下错误: “Unity”已拥有为“CommonServiceLocator”定 ...

  7. [c++] Class

    也是醉了,一个.h文件就有这么多细节问题: 初始化列表,使用{} 也可以. 类中的引用和const变量,必须立即在初始化列表中提前初始化. 常成员函数,const 放在函数后, 常成员函数即不能改变成 ...

  8. java中hashMap的排序

    hashMap排序,示例: private void test(){ Map<String, List<String>> unSupportedDatesMap=new Has ...

  9. 使用Spire.Barcode程序库生成二维码

    使用Spire.Barcode程序库生成二维码 某天浏览网页发现了一个二维码的程序库.它的描述说他可以扫描二维码图像.我很感兴趣,想试试他是不是会有用.所以我就用了些方法扫描二维码图像来测试一下.结果 ...

  10. Oracle管理磁盘空间和资源

    1.可恢复的空间分配 2.可移动表空间 3.Oracle段收缩功能 4.Oracle数据库资源管理 Reference 1.可恢复的空间分配 1.1 了解可恢复的空间分配 一般情况,我们发出一个大型数 ...