js008-BOM

本章内容:

1、理解window对象-BOM的核心

2、控制窗口、框架和弹出窗口

3、利用location对象中的页面信息

4、使用navigation对象了解浏览器

ECMAScript是JavaScript的核心。BOM(浏览器对象模型)才是JavaScript真正的核心。

8.1 window对象

BOM核心对象是window,表示浏览器的一个实例。

 

8.1.1全局作用域

由于window对象也是ECMAScript种的global对象的角色,所以所有全局作用域中声明的变量,函数都会变成window对象的属性和方法。如:

var age = 29;

function sayAge(){

alert(this.age);

}

alert(window.age);

sayAge();

window. sayAge ();

结果都是29.。

var age = 29;

window.color = "red";

//在IE< 9时抛出错误,其他浏览器都返回false

delete window.age;

//在IE< 9时抛出错误,其他浏览器都返回true

delete window.color;   //true

alert(window.age);   //29

alert(window.color);   //undefined

定义全局变量和在window对象上直接定义属性有差别:全局变量不能通过delete操作符删除,而直接在window对象上直接定义的属性可以。

使用var定义的window属性有个[[configurable]]的特性,其默认值为false,所以不能用delete删除

//抛出错误

var newValue = oldvalue;

//不会抛出错误,这只是一次属性查询

//newValue的值是Undefined

var newValue = window.oldvalue;

尝试访问未声明的变量会抛出错误,但是通过查询window对象,可以知道某个为生命的变量是否存在

8.1.2窗口关系及框架

window.frames[0];

window.frames["topframe"];

top.frame[0];

top.frames["topframe"];

frame[0];

frames["topframe"];

window.frames[1];

window.frames["leftframe"];

top.frame[1];

top.frames["leftframe"];

frame[1];

frames["leftframe"];

window.frames[2];

window.frames["rightframe"];

top.frame[2];

top.frames["rightframe"];

frame[2];

frames["rightframe"];

总体来说没怎么看明白parent这个东西。

8.1.3窗口位置

用来修改window对象位置。如IE、Safari、Opera、Chrome提供的 screenLeft和screenTop。Firefox的screenX和screenY,Safari、Chrome也支持这连个属性。

下列代码可以跨浏览器去的窗口左边和上边的位置

var leftPos = (typeof window.screenLeft == "number") ?

window.screenLeft : window.screenX;

var topPos = (typeof window.screenTop == "number") ?

window.screenTop : window.screenY;

//将窗口移动到屏幕左上角

window.moveTo(0 , 0);

//将窗口向下移动100px

window.moveBy(0 ,100);

//将窗口移动到(200 , 300)

window.moveTo(200 , 300);

//将窗口向左移动50px

window.moveBy(-50 ,0);

使用moveTo()  moveBy()方法可能将窗口精确的移动到一个新位置。这两个方法都接收两个参数。其中moveTo()就收的是新位置的x和y值。

moveBy()接收的是在水平和垂直方向上移动的像素数。

这两个方法会被浏览器禁用 ,不适用与框架。只能对最外层的window对象使用。

8.1.4窗口大小

可以取得可视窗口大小的属性:clinetWidth和clinetHeight

调整浏览器窗口的大小的方法:resizeTo()和resizeBy()。用法和前面的moveTo(), moveBy()用法一样。同样不适用框架,只能在window最外层使用,同样会被浏览器禁用。

8.1.5导航和打开窗口

使用window.open()方法。可接收四个参数:要加载的URL(通常指使用第一个)、窗口目标、一个特性字符串和一个表示新页面是否取代浏览器历史记录中当前加载页面的布尔值(打不开页面时使用)。

1、弹出窗口

2、安全限制

3、弹出窗口屏蔽程序

8.1.6间歇调用和超时调用

JS是单线程语言

超时调用需要使用window对此昂的setTimeou()方法,接收两个参数:要执行的代码(最好不要是字符串)和以毫秒表示的时间

8.1.7系统对话框

通过alert()  confirm()  prompt()方法可以调用系统对话框向用户显示消息。

8.2 location对象

location对象是最有用的BOM对象之一,它提供了一些导航功能,也提供了与当前窗口中加载的文档有关的信息。它是一个很特别的对象,既是window对象的属性也是document对象的属性。所以window.location 和 document.location引用的是同一个对象

以下为location对象的所有属性

属性名

例子

说明

hash

“#contents”

返回URL中的hash(#后面跟0个或多个字符),如果URL中不包含散列,则返回空字符串

host

“www.wrox.com:80”

返回服务器和端口号(如果有)

hostname

“www.wrox.com”

返回服务器名称(不带端口号)

href

“http:/ www.wrox.com”

返回当前加载页面的完整URL,location对象的toString()方法也返回这个值

pathname

“/WileyCDA/”

返回URL中的目录和(或)文件名

port

“8080”

返回URL中指定的端口号,如果没有端口号,返回控制符串

protocol

“http:”

返回页面使用的协议

search

“?q=javascript”

返回URL的查询字符串,以?开头

8.2.1查询字符串参数

8.2.2位置操作

使用location对象来改变浏览器的位置,最常用的方法是assign()方法,并为其传递一个URL.

location.assign(“http:/ www.wrox.com”);

8.3 navifator对象

8.3.1检测插件

检测浏览器中是否安装了特定的插件是最常见的检测历程。在IE中可以用plugins数组拉埃达到这个目的。该数组中的每一项都包含下列属性。

1、  name:插件名称

2、  description:插件描述

3、  filename:插件的文件名

4、  length:插件做出的MIME类型数量

在IE中检测插件的为方式就是使用转悠的ActiveXObject类型,并尝试创建一个热定插件的实例

8.3.2注册处理程序

Firefox 为navigator对象新增了registerContentHander()和registerProtocolHander()方法。这两个方法可以让一个站点执行它可以处理特定类型的信息。

registerContentHander()方法接收三个参数:要处理的MIME类型、可以处理该MIME类型的页面的URL、应用程序的名称。

8.4 screen对象

一个在js变成中用处不大的对象,基本上只用来表明客户端的能力。

8.5 history对象

该对象保存着用户上网的历史记录。从窗口被打开的那一刻起。history是window对象的属性。

使用go()方法可以在用户的历史记录中任意跳转。可以向前向后。

history.go(1);

history.back();

//后退一页

history.go(1);

history.forward()

//前进一页

声明:本博客为http://www.cnblogs.com/lal-fighting/原创发布,未经允许禁止私自转载或抄袭!!!

js008-BOM的更多相关文章

  1. HTML BOM Browser对象

    BOM:Browser Object Model,即浏览器对象模型,提供了独立于内容的.可以与浏览器窗口进行互动的对象结构. Browser对象:指BOM提供的多个对象,包括:Window.Navig ...

  2. 一步步学习javascript基础篇(7):BOM和DOM

    一.什么是BOM.什么是DOM BOM即浏览器对象模型,主要用了访问一些和网页无关的浏览器功能.如:window.location.navigator.screen.history等对象. DOM即文 ...

  3. BOM,DOM,ECMAScripts三者的关系

    一:DOM 文档对象模型(DOM)是表示文档(比如HTML和XML)和访问.操作构成文档的各种元素的应用程序接口(API) DOM是HTML与JavaScript之间沟通的桥梁.   DOM下,HTM ...

  4. javascript学习之BOM

    BOM是browser object model的缩写,简称浏览器对象模型.先看看下面这张图 window对象是BOM的顶层(核心)对象,所有对象都是通过它延伸出来的,也可以称为window的子对象. ...

  5. BOM以及定时器

    一.BOM 1.操作浏览器的一些方法 (浏览器对象模型) 2.window是is中的顶级变量,是一个全局的变量,所有人都可以访问到它,基本 的方法和属性 (document,alert,console ...

  6. js浏览器对象模型(BOM)

    浏览器对象模型(Browser Object Model,BOM):浏览器为js提供的对象集合. 1 windows对象 windows对象:表示浏览器的框架以及与其相关的内容,比如滚动条和导航栏图标 ...

  7. BOM操作

    BOM操作 //浏览器对象模型 opener=window.open(页面的url,打开方式) opener.document.body.style.background="red" ...

  8. 什么是BOM头,BOM头有什么影响,怎么去掉BOM头

    什么是bom头? 在utf-8编码文件中BOM在文件头部,占用三个字节,用来标示该文件属于utf-8编码,现在已经有很多软件识别bom头,但是还有些不能识别bom头,比如PHP就不能识别bom头,这也 ...

  9. Txt格式配置表无法解析的问题——BOM

    今天再次遇到同一个问题:策划给来一个Txt格式配置表,我用解析类去读取,返回的结果为空.解析类参数是:主键key,文件名fileName,错误提示errorTip. 写读取语句的时候,主键key我是直 ...

  10. BOM对象有哪些:

    BOM对象有哪些: 1.window对象 ,是JS的最顶层对象,其他的BOM对象都是window对象的属性: 2.document对象,文档对象: 3.location对象,浏览器当前URL信息: 4 ...

随机推荐

  1. DIV+CSS 星号*

    常常我们在DIV+CSS布局的时候会遇到2处使用星号“*”,一个为以星号*没有命名名称的CSS选择器:另外一个是在CSS选择器里以*开头的CSS属性单词样式-CSS星号-CSS *知识介绍.接下来DI ...

  2. JS 获取上一层目录

    派生到我的代码片 <script type="text/javascript"> //返回当前工作目录 function GetCurrDir(){ var pathN ...

  3. extJs学习基础2

    一个登陆界面: Ext.onReady(function(){ Ext.define('Login', { //renderTo: Ext.getBody(), extend: 'Ext.window ...

  4. 学习Spring(一) 实例化Spring IoC容器

    实例化Spring IoC容器 1,读取其配置来创建bean实例 2,然后从Spring IoC容器中得到可用的bean实例 Spring提供两种IoC容器实现类型 a,一种为bean工厂 b,应用程 ...

  5. 【POJ 1556】The Doors 判断线段相交+SPFA

    黑书上的一道例题:如果走最短路则会碰到点,除非中间没有障碍. 这样把能一步走到的点两两连边,然后跑SPFA即可. #include<cmath> #include<cstdio> ...

  6. AOP 注入失败的问题

    启用了AOP 后,报这样的类似错误: Error creating bean with name 'bpmpSysUserService': Injection of autowired depend ...

  7. 浅谈jQuery页面的滚动位置scrollTop、scrollLeft

    Web页面常常比显示该页面的浏览器窗口还要大,因为Web文档具有很多内容,往往会导致页面比浏览器还要高,有时候甚至还要宽,这迫使访问者通过滚动来查看整个页面(如图10-8所示).当访问者滚动页面的时候 ...

  8. 查找Linux系统中的占用磁盘空间

    目录的来查看空间占用情况 du -sh /* 先看看根目录下面 让文件夹下的文件让文件按大小排序 方法一:# ls -lhSl 长格式显示,h human readable模式,大小单位为M,G等易读 ...

  9. 简进祥-SVN版本控制方案:多分支并行开发,多环境自动部署

    两地同时开发一个产品,目前线上有3个环境:测试环境.预发布环境.生产环境.目前系统部署采用jenkins自动化部署工具 用jenkins部署的方案 jenkins 测试环境:配置了各个分支的svn 地 ...

  10. 根据xsd生成C#类

    var file = "1.xsd"; // Get the namespace for the schema. CodeNamespace ns = Processor.Proc ...