浏览器对象模型(Browser Object Model (BOM)) Window 对象
1 : window.open(url);
//打开新的页面
eg: window.open("http://www.baidu.com","newwindow","height=100,width=400,top=0,left=0,toolbar=no,menubar=no,scrollbars=no, resizable=no,location=no, status=no");
高为100,宽为400,距屏顶0象素,屏左0象素,无工具条,无菜单条,无滚动条,不可调整大小,无地址栏,无状态栏
window.open("http://www.baidu.com")
2,window.location="http://www.baidu.com";
补充:
location.hostname 返回 web 主机的域名
location.pathname 返回当前页面的路径和文件名
location.port 返回 web 主机的端口 (80 或 443)
location.protocol 返回所使用的 web 协议(http:// 或 https://)
3,window.location.href="http://www.baidu.com"
可以控制当前页面跳转
4,window.history 对象包含浏览器的历史
history.back() - 与在浏览器点击后退按钮相同
history.forward() - 与在浏览器中点击按钮向前相同
history.go(-3);//回走三次
5,window的定时调用函数
setInterval("函数名称","毫秒")
clearInterval()
6,延迟调用:
setTimeout("函数名称","时间") 方法
返回id 唯一标识
clearTimeout(id)方法来停止执行函数代码
7,offsetHeight, offsetWidth
返回元素的高度和宽度,以像素为单位
8,offsetLeft
返回当前元素的左边界到它的包含元素的左边界的偏移量,以像素为单位。
offsetTop
当前元素的上边界到它的包含元素的上边界的偏移量,以像素为单位。
1. BOM 浏览器对象模型
BOM提供了很多对象,用于访问浏览器的功能,这些功能与任何网页内容无关。BOM的核心对象是window,它表示浏览器的一个实例,在浏览器中window对象有双重角色既是通过javascript访问浏览器窗口的一个接口,又是ECMAScript规定的Global对象。
1.窗口位置
screenLeft和screenTop属性返回窗口相对于屏幕的X和Y坐标。(火狐浏览器不支持)
screenX和screenY属性返回窗口相对于屏幕的X和Y坐标。(ie浏览器不支持)
pageXOffset 设置或返回当前页面相对于窗口显示区左上角的 X 位置。
pageYOffset 设置或返回当前页面相对于窗口显示区左上角的 Y 位置。
IE8及更早IE版本不支持该属性,但可以使用 "document.body.scrollLeft" 和 "document.body.scrollTop" 属性 。
2.窗口大小
innerWidth 页面视图区的宽度
innerHeight 页面视图区的高度
outerWidth 浏览器窗口的宽度
outerHeight 浏览器窗口的高度
所有主流浏览器都支持innerWidth,innerHeight,outerWidth,outerHeight 属性。注意:IE8及更早IE版本不支持这些属性。
3. screen对象
屏幕总宽度/高度:
screen.width
screen.height
可用宽度/高度:
screen.availWidth
screen.availHeight
颜色深度:
screen.colorDepth
颜色分辨率:
screen.pixelDepth
4.导航和打开窗口
window.open()
可以导航到一个特定的URL,也可以打开一个新的浏览器窗口,该方法会返回一个指向新窗口的引用。引用的对象与其他的window对象类似。
参数:
1)要加载的URL
2)窗口目标,框架名
特殊名:
_self 当前浏览器页面
_parent 当前页面父页面
_top 当前页面顶级页面
_blank 新页面
3) 一个特定字符串
是用逗号分隔的设置字符串
channelmode=yes|no|1|0 是否要在影院模式显示 window。默认是没有的。仅限IE浏览器
directories=yes|no|1|0 是否添加目录按钮。默认是肯定的。仅限IE浏览器
fullscreen=yes|no|1|0 浏览器是否显示全屏模式。默认是没有的。在全屏模式下的 window,还必须在影院模式。仅限IE浏览器
width=pixels 窗口的宽度.最小.值为100
height=pixels 窗口的高度。最小.值为100
left=pixels 该窗口的左侧位置
location=yes|no|1|0 是否显示地址字段.默认值是yes
menubar=yes|no|1|0 是否显示菜单栏.默认值是yes
resizable=yes|no|1|0 是否可调整窗口大小.默认值是yes
scrollbars=yes|no|1|0 是否显示滚动条.默认值是yes
status=yes|no|1|0 是否要添加一个状态栏.默认值是yes
titlebar=yes|no|1|0 是否显示标题栏.被忽略,除非调用HTML应用程序或一个值得信赖的对话框.默认值是yes
toolbar=yes|no|1|0 是否显示浏览器工具栏.默认值是yes
top=pixels 窗口顶部的位置.仅限IE浏览器
4)表示新页面是否取代浏览器历史记录中当前加载页面的布尔值
如果传递了第二个参数,而且该参数是已有窗口或框架的名称,就会在具有该名称的窗口或框架中加载第一个参数指定的URL
调整窗口大小
//调整到100*100
resizeTo(100,100);//接受浏览器窗口的新高度和新宽度
//调整到200*150
resizeBy(100,50); //接受新窗口与原窗口的宽度和高度之差
//调整到300*300
resizeTo(300,300)
移动窗体
多用于新建窗体
window.moveTo(0,0); 接受的是新位置的x和y坐标值
window.moveBy(0,100);接受的是在水平和垂直方向上移动的像素值。
滚动条
scrollBy(xnum,ynum) 方法可把内容滚动指定的像素数。注意: 要使此方法工作 window 滚动条的可见属性必须设置为true!(overflow:scroll)
scrollTo(xpos,ypos) 方法可把内容滚动到指定的坐标。
例如:
创建新窗体
var w = window.open("http://www.baidu.com","_blank","toolbar=yes, location=yes, directories=no, status=no, menubar=yes, scrollbars=yes, resizable=no, copyhistory=yes, width=400, height=400");
改变窗体大小
w.resizeTo(400,200);
5.间歇调用和超时调用
javascript是单线程语言,但是可以通过超时值和间歇时间来调度代码在特定时刻执行
1) setTimeout();
该方法返回一个数值ID,表示超时调用,这个超时调用ID是计划执行代码的唯一标识符通过它来取消超时调用。可以通过clearTimeout(ID);
参数:
1.要执行的代码
2.以毫秒表示的时间。
例如:
一秒后调用
var id = setTimeout(function(){
alert(1000);
},1000);
console.log(id);
//清除
clearTimeout(id);
2) setInterval();
按照指定的时间间隔重复执行代码,直到间歇调用被取消或页面被卸载。调用该方法也会返回一个间歇调用ID,该ID可以用户在将来某个时刻取消间歇调用
参数:
1.要执行的代码
2.以毫秒表示的时间。
clearInterval(ID); //取消间歇调用
7. location对象 ,是最有用的BOM对象之一,提供了与当前窗口中加载的文档有关的信息,还提供一些导航功能。location是个神奇的对象,既是window的对象也是document的对象。
console.log(window.location == document.location);//true
属性:
host 返回服务器名称和端口号
hostname 返回不带端口号的服务器名称
href 返回当前加载页面的完整URL
pathname 返回URL的目录和文件名
port 返回URL中指定的端口号
protocol 返回页面使用的协议
search 返回URL的查询字符串。这个字符串以问号开头
方法:
assign() 传递一个url参数,打开新url,并在浏览记录中生成一条记录。
replace() 参数为一个url,结果会导致浏览器位置改变,但不会在历史记录中生成新记录
reload() 重新加载当前显示的页面,参数可以为boolean类型,默认为false,表示以最有效方式重新加载,可能从缓存中直接加载。如果参数为false,强制从服务器中重新加载
为location.href; window.location 设置为一个URL值,也会以该值调用assign()方法。以下三句话效果一样
window.location="http://www.baidu.com";
location.href="http://www.baidu.com"
location.assign("http://www.baidu.com");
8.history对象
该对象保存着用户上网的历史记录。出于安全方面的考虑,开发人员无法得知用户浏览过的URL,不过借由用户访问过的页面列表,同样可以在不知道实际URL的情况下实现后退前进,注意: 没有应用于History对象的公开标准,不过所有浏览器都支持该对象。
length 返回历史列表中的网址数
注意:Internet Explorer和Opera从0开始,而Firefox、Chrome和Safari从1开始。
back() 加载 history 列表中的前一个 URL
forward() 加载 history 列表中的下一个 URL
go() 加载 history 列表中的某个具体页面
负数表示向后跳转,正数表示向前跳转。
2. 特殊的css
1) 元素几何尺寸
getBoundingClientRect()
left/x 元素左上角的x坐标
top/y 元素左上角的y坐标
right 元素右上角的x坐标
bottom 元素右上角的y坐标
with 元素宽度
height 元素高度
2) 任何元素的只读属性
以css像素返回它的屏幕尺寸,返回的尺寸包括元素的边框和内边距
offsetWidth
offsetHeight
坐标,返回元素的X和Y坐标。
offsetLeft
offsetTop
父元素,
offsetParent 指定这些属性相对的父元素
clientWidth
clientHeight
类似于offsetWidth,offsetHeight,但是他们不包含边框,只包含内容和内边距
scrollWidth
scrollHeight
元素的内容+内边距+任何溢出内容的尺寸。
3) 第三个维度 : z-index
left,right,top,bottom属性是容器元素中的二维坐标中指定X,Y坐标,z-index定义了第三个维度:它允许元素的堆叠次序,并指示两个或多个重叠元素中的哪一个元素应该绘制在其他的上面。默认值为0,可以是负数也可以是正数,当两个或者多个元素重叠在一起的时候,他们是按照从低到高的z-index顺序绘制。只针对兄弟元素应用堆叠效果。
4) 元素的显示和可见性
visibility:
hidden 元素不可见,但是在文档布局中保留了它的空间。
visible 元素可见
display
none 元素不可见,在文档布局中不给它分配空间,它的各边元素会合拢,就当它不存在过。在展开和折叠轮廓的效果时,display属性很有用。
不过visibility,display对绝对定位和固定定位的元素的影响是等价的。
5) 颜色,透明度
opacity 透明度:0~1之间的数字
filter: IE中表示透明度
常用表示透明度的方法
opacity: 0.75;
filter:alpha(opacity=75)