window对象

BOM的核心对象是window,它表示浏览器的一个实例。在浏览器中,window对象有双重角色,它既是通过JavaScript访问浏览器窗口的一个接口,又是ECMScript规定的Global对象。

全局作用域

由于window对象同时扮演着ECMAScript中Global对象的角色,因此所有在全局作用域中声明的变量、函数都会变成window对象的属性和方法。来看下面的例子:

var age=29;
function sayAge(){
alert(this.age);
}
alert(window.age); //
sayAge(); //
window.sayAge(); //

定义全局变量与在window对象上直接定义属性还有一点差别就是:全局变量不能通过delete操作符删除,而直接在window对象上定义的属性可以,例如:

var age=29;
window.color="red"; delete window.age' //在IE<9时抛出错误,在其他所有浏览器中都返回false delete window.color //在IE<9时抛出错误,在其他所有浏览器中都返回true
alert(window.age) ;//29
alert(window.color); //undefined

原因是使用var语句添加的window属性有一个名为[[Configurable]]的特性,这个特性的值被设置为false,因此这样定义的属性不可通过delete操作符删除。
另外,还要记住一件事:尝试访问未声明的变更会抛出错误,但是通过查询window对象,可以知道某个可能未声明的变更是否存在,如:

//这里会抛出错误,因为oldValue未定义
var newValue=oldValue; //这里不会抛出错误,因为这是一次属性查询
//newValue的值是undefined
var newValue=window.oldValue;

窗口关系及框架

top对象始终指向最高(最外)层的框架,也就是浏览器窗口。与框架有关的最后一个对象是self,它始终指向window;实际上,self和window对象可以互换使用。引入
self对象的目的只是为了与top和parent对象对应起来,因此它不格外包含其它值。

窗口位置

使用下面的代码可以跨浏览器取得窗口左边和上边的位置。

var leftPos=(typeof windwow.screenLeft=="number")?
window.screenLeft:window.screenX;
var topPos=(typeof windwow.screenTop=="number")?
window.screenTop:window.screenY;

使用resizeTo()和resizeBy()方法可以调整浏览器窗口的大小 。

导航和打开窗口

window。open("http://www.wrox.com","topFrame");

如果有一个名叫"topFrame"的窗口或者框架,就会在该窗口或框架加载这个URL;否则,就会创建一个新窗口并将其命名为"topFrame".

在Chrome中,将新创建的标签页的opener属性设置为null,即表示在单独的进程中运行新标签页,如下所示:

var wroxWin=window.open("http://www.wrox.com","wroxWindow","height=400,width=400,top=10,left=10,resizable=yes");
wroxWin.opener=null;

将opener属性设置为Null就是告诉浏览器新创建的标签页不需要与打开它的标签页通信,因此可以在独立的进程中运行。

间隙调用和超时调用

JavaScript是一个单线程序的解释器,因此一定时间内只能执行一段代码。为了控制要执行的代码,就有一个JavaScript任务队列。这些任务会按照将它们添加到队列的顺序执行。
setTimout()的第二个参数告诉JavaScript再过多长时间把当前任务添加到队列中。如果队列是空的,那么添加的代码会立即执行;如果队列不是空的,那么它就要等前面的代码
执行完以后再执行。
要取消尚未执行的超时调用计划,可以调用clearTimeout()方法并将相应的超时调用ID作为参数传递给它,如下所示:

//设置超时调用
var timeoutId=setTimout(function(){
alert("Hello world!");
},1000);
//注意:把它取消
clearTimeout(timeoutId);

间隙调用与超时调用类似,只不过它会按照指定的时间间隔重复执行代码,直至间歇调用被取消或者页面被卸载。设置间歇调用的方法是setInterval().

//不建议传递字符串
setInterval("alert('Hello world!')",10000); //推荐的调用方式
setInterval(function(){
alert("Hello world!");
},10000);

虽然这两种调用方式都没有问题,但由于传字符串可能导致性能损失,因此不建议以字符串作为第一个参数。
也可以用clearInterval()方法并传入相应的间隙ID来取消。以下是一个常见的使用间歇调用的例子:

var num=0;
var max=10;
var intervalId=null; function incrementNumber(){
num++;
//如果执行次数达到max设定的值,则取消后续尚未执行的调用
if(num==max)
{
clearTimeout(intervalId);
alert("Done");
}
}
intervalId=setInterval(incrementNumber,500);

这个例子也可以用超时调用来实现,如下:

var num=0;
var max=10; function incrementNumber(){
num++;
//如果执行次数未达到max设定的值,则设置另一次超时调用
if(num<max)
setTimout(incrementNumber,500);
else
alert("Done");
}
setTimout(incrementNumber,500);

一般认为,使用超时调用来模拟间歇调用是一种最佳模式。在开发环境下,很少使用真正的间歇调用,原因是后一个间歇调用可能会在前一个间歇调用结束之前启动。
而像前面示例中那样使用超时调用,则完全可以避免这一点。所以,最好不要使用间歇调用。

更简洁的写法:

setTimeout(function(){
//processing
setTimeout(arguments.callee, interval);
}, interval);

JavaScript高级程序设计学习笔记--BOM的更多相关文章

  1. JavaScript高级程序设计---学习笔记(一)

    今天,2017.3.17开始利用课余时间仔细学习<JavaScript高级程序设计>,将需要掌握的知识点记录下来,争取把书里的所有代码敲一遍并掌握. 1.标识符命名最好是第一个字母小写,剩 ...

  2. javascript高级程序设计学习笔记

    javascript高级程序设计,当枕头书已经好久了~zz  现在觉得自己在js的开发上遇到了一些瓶颈,归根究底还是基础太薄弱,所以重新刷一遍js高程希望有更新的认识. 一.javascript简介 ...

  3. JavaScript高级程序设计学习笔记第八章--BOM

    1.间歇调用和超时调用: 超时调用:需要使用 window 对象的 setTimeout()方法,它接受两个参数:要执行的代码和以毫秒表示的时间(即在执行代码前需要等待多少毫秒).其中,第一个参数可以 ...

  4. JavaScript高级程序设计---学习笔记(二)

    面向对象程序设计1.属性类型.定义多属性.读取属性特性对象的属性在创建时都带有一些特征值,JavaScript通过这些特征值来定义它们的行为.这些特性是为了实现JavaScript引擎用的,因此不能直 ...

  5. JavaScript高级程序设计学习笔记第一章

    作为学习javascript的小白,为了督促自己读书,写下自己在读书时的提炼的关键点. 第一章: 1.JavaScript简史:Netscape Navigator中的JavaScript与Inter ...

  6. Javascript高级程序设计学习笔记一

    看完w3school的javascript的概念,有点基础,开始红皮书的路程,今晚总结前二章的心得. 第一章:javascript简介 重点是javascript的实现是由 ECMAScript(核心 ...

  7. javascript 高级程序设计 学习笔记

    <!--<script> // 异步请求封装 IE6即以上浏览器 // ajax(url,fnSucc,selectID,fnFaild) //url 请求地址 //fnSucc 异 ...

  8. JavaScript高级程序设计学习笔记--面向对象的程序设计(二)-- 继承

    相关文章: 面向对象的程序设计(一) — 创建对象 http://www.cnblogs.com/blackwood/archive/2013/04/24/3039523.html 继承 继承是OO语 ...

  9. JavaScript高级程序设计学习笔记之事件

    1.事件流 事件流描述的是从页面中接收事件的顺序. 事件冒泡 IE的事件流叫做事件冒泡(event bubbling),即事件开始时由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播 ...

随机推荐

  1. C#基础系列——小话泛型

    前言:前面两章介绍了C#的两个常用技术:C#基础系列——反射笔记 和 C#基础系列——Attribute特性使用 .这一章来总结下C#泛型技术的使用.据博主的使用经历,觉得泛型也是为了重用而生的,并且 ...

  2. NOSQL数据模型和CAP原理

    NOSQL数据模型和CAP原理 http://blog.sina.com.cn/s/blog_7800d9210100t33v.html 我本来一直觉得NoSQL其实很容易理解的,我本身也已经对NoS ...

  3. RGW/SWIFT对象存储性能测试工具--COSBench安装

    Cosbench是Intel的开源云存储性能测试软件,COSBench目前已经广泛使用与云存储测试,并作为云存储的基准测试工具使用 https://github.com/intel-cloud/cos ...

  4. jQuery瀑布流简单示例

    1,以下demo是基于window的滚动  

  5. bzoj2683

    2683: 简单题 Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 1018  Solved: 413[Submit][Status][Discuss] ...

  6. Alpha阶段第六次Scrum Meeting

    情况简述 Alpha阶段第六次Scrum Meeting 敏捷开发起始时间 2016/10/27 00:00 敏捷开发终止时间 2016/10/28 00:00 会议基本内容摘要 提出了目前阶段遇到的 ...

  7. Html中<a>标签的样式的设置

    html中<a>标签的样式的设置.. ------------------------ <html> <head> <title>这是网页选项卡的名称& ...

  8. 生成彩条的MATLAB代码

    clc;close all;clear %read image % RGBimga = imread('bmpinput_1080p.bmp'); RGBimga = imread('bmpinput ...

  9. 大熊君大话NodeJS之------MongoDB模块(额外篇)

    一,开篇分析 这篇属于扩展知识篇,因为在下面的文章中会用到数据库操作,所以今天就来说说它(Mongodb模块). (1),简介 MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为 ...

  10. CF memsql Start[c]UP 2.0 B

    CF memsql Start[c]UP 2.0 B B. Distributed Join time limit per test 1 second memory limit per test 25 ...