6. Javscript学习笔记——BOM
6. BOM
6.1 widow对象
全局作用域:
window是浏览器的一个实例
window对象同时扮演着ECMAScript中的Global对象的角色,因此所有在全局作用域中声明的变量、函数都会变成window对象的属性和方法
访问未声明的变量会抛出错误,但是通过window.属性 访问时会显示undefined
访问window里的对象,不用加window.
窗口位置:
window.screenLeft 和 window.screenTop 属性分别表示窗口相对于屏幕左边和上边的位置,FireFox 只支持screenX 和screenY 属性,Chrome支持两种
跨浏览器使用:
var leftPos =(typeof window.screenLeft =="number") ? window.screenLeft : window.screenX ;var topPos = (typeof window.screenTop == "number") ? window.screenTop : window.screenY;如果支持screenTop就用screenTop,否则就用screenY
窗口大小:
innerWidth innerHeight 分别表示页面的宽和高,outerWidth 和 outerHeight表示加上边框的宽和高chrome两者都是页面的宽和高
导航和打开窗口:
window.open():
第一个参数是:URL 第二个是:窗口目标(在那里打开,_self:当前页面 _blank:新窗口 _parent:父框架 'xxxx':窗口名称,没有的话就新建一个名为xxxx的窗口)
第三个是:打开新窗口的样式
参数 值 说明 top 数值 表示新窗口的上坐标。不能是负值 left 数值 表示新窗口的左坐标。不能是负值 height 数值 表示新窗口的高度。不能小于100 width 数值 表示新窗口的宽度。不能小于100 window.open("http://www.wrox.com/", "wroxWindow", "height=400,width=400,top=10,left=10");这行代码会打开一个窗口,初始大小为 400×400 像素,并且距屏幕上沿和左边各 10 像素。
window.open()方法会返回一个指向新窗口的引用。引用的对象与其他 window 对象大致相似(
window.open().alert(1)),但我们可以对其进行更多控制。例如,有些浏览器在默认情况下可能不允许我们针对主浏览器窗口调整大小或移动位置,但却允许我们针对通过 window.open()创建的窗口调整大小或移动位置。var wroxWin = window.open("http://www.wrox.com/","wroxWindow", "height=400,width=400,top=10,left=10,resizable=yes");
//调整大小 wroxWin.resizeTo(500,500);
//移动位置 wroxWin.moveTo(100,100);
调用 close()方法还可以关闭新打开的窗口。
wroxWin.close();
间歇调用和超时调用:
setTimeOut(超时调用):
它有两个参数:要执行的代码和以毫秒表示的时间(即在执行代码前需要等待多少毫秒)。第一个参数可以使字符串形式的代码,也可以是函数。
setTimeOut(function(){alert(1)},2000);//推荐,字符串形式可能降低性能不建议使用:
setTimeOut("alert(1)",2000); //两秒后执行alert(1)
调用 setTimeout()之后,该方法会返回一个数值 ID,这个超时调用 ID 是计划执行代码的唯一标识符,可以通过它来取消超时调用。要取消尚未执行的超时调用计划,可以调用clearTimeout()方法并将相应的超时调用 ID 作为参数传递给它,
var id = setTimeout(xxx); clearTimeOut(id);
setInterval(间歇调用):
它接受的参数与 setTimeout()相同
强烈不建议使用字符串
setInterval(function(){alert(1)},2000);//每隔两秒就弹出对话框
clearInterval(id);//同上
6.2 location对象
location == document.location == window.location
| 属性 | 例子 | 说明 |
|---|---|---|
| location.hash | #contents | 返回url中的hash |
| location.host | www.xxx.com:80 | 返回服务器名称和端口号(如果有) |
| location.hostname | www.xxx.com | 返回不带端口号的服务器名称 |
| location.href | http://www.xxx.com | 返回当前加载页面的完整URL |
| location.pathname | /index/a/ | 返回URL中的目录和(或)文件名 |
| location.port | 8080 | 返回URL中指定的端口号。如果URL中不包含端口号,则 |
| location.protocol | http: | 返回页面使用的协议。通常是http:或https: |
| location.search | ?keyword=xxx | 返回URL的查询字符串。这个字符串以问号开头 |
查询字符串参数:
function getArgs(){
if(location.search == ''){
return 'nonono';
}
var qs = location.search.substr(1);
var args = {};//保存参数,
var items = qs.split("&");//取得每一项
var item=null,name=null,value=null;
for(var i=0;i<items.length;i++){
item=items[i].split("=");
name = decodeURIComponent(item[0]);//url解码
value = decodeURIComponent(item[1]);
args[name] = value;
}
return args;
}
alert(getArgs());
位置操作:
location.assign("http://qq.com");
location.href = 'http://qq.com';
location = 'http://qq.com';//这三个都是修改当前页面
location.hash = 'haha';
location.search='id=1001';
等等
location.reload();//重新加载(有可能从缓存加载)
location.reload(true);//重新加载(从服务器加载)
location.replace('url'); //将当前页面改为url指向的页面
6.3 navigator对象
6.4 screen对象
JavaScript 中有几个对象在编程中用处不大,而 screen 对象就是其中之一。screen 对象基本上只用来表明客户端的能力,其中包括浏览器窗口外部的显示器的信息,如像素宽度和高度等。每个浏览器中的screen 对象都包含着各不相同的属性。
6.5 history对象
history.go(1)//前进一页
history.go(-1)//后退一页
history.go(-2) //后退2页
history.go('baidu.com')/跳转到最近的baidu.com页面
history.back()//后退一页
history.forward()//前进一页
6. Javscript学习笔记——BOM的更多相关文章
- JavaScript高级程序设计学习笔记--BOM
window对象 BOM的核心对象是window,它表示浏览器的一个实例.在浏览器中,window对象有双重角色,它既是通过JavaScript访问浏览器窗口的一个接口,又是ECMScript规定的G ...
- javascript学习笔记 BOM和DOM详解
js组成 我们都知道, javascript 有三部分构成,ECMAScript,DOM和BOM,根据宿主(浏览器)的不同,具体的表现形式也不尽相同,ie和其他的浏览器风格迥异. 1. DOM 是 W ...
- 2. Javscript学习笔记——引用类型
2. 引用类型 2.1 Object类型 Object 是一个基础类型,其他所有类型都从 Object 继承了基本的行为. 对象是一个包含相关数据和方法的集合(通常由一些变量和函数组成,我们称之为对象 ...
- js 学习笔记---BOM
window对象 1. window 对象是Global对象,在全局作用域中声明的变量和函数都可以通过window.来访问.跟直接在window上添加属性效果一样.唯一的区别就是delete时,如果是 ...
- Extjs 学习笔记1
学习笔记 目 录 1 ExtJs 4 1.1 常见错误处理 4 1.1.1 多个js文件中有相同的控件,切换时无法正常显示 4 1.1.2 Store的使用方法 4 1.1.3 gridPanel ...
- 《JavaScript语言精粹》学习笔记
一.in的用法 for...in 枚举一个对象的所有可枚举属性 检测DOM/BOM属性 if ("onclick" in elem) { // 元素支持onclick } if ( ...
- AJax 学习笔记二(onreadystatechange的作用)
AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...
- DBus学习笔记
摘要:DBus作为一个轻量级的IPC被越来越多的平台接受,在MeeGo中DBus也是主要的进程间通信方式,这个笔记将从基本概念开始记录笔者学习DBus的过程 [1] DBus学习笔记一:DBus学习的 ...
- Webpack新手入门教程(学习笔记)
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; text-align: center; font: 30.0px Helvetica; color: #000000 } ...
随机推荐
- SpringMVC 2.5.6 +Hibernate 3.2.0
spring MVC配置详解 现在主流的Web MVC框架除了Struts这个主力 外,其次就是Spring MVC了,因此这也是作为一名程序员需要掌握的主流框架,框架选择多了,应对多变的需求和业务时 ...
- javascript总结29 :递归与回调函数
1 递归函数 -递归的实质就是函数自己调用自己. -递归注意点:递归必须有跳出条件,否则是死循环. var i = 1; fn(); function fn(){alert("从前有座山,山 ...
- 使用word 2013 发布csdn博客
目前大部分的博客作者在用Word写博客这件事情上都会遇到以下3个痛点: 1.所有博客平台关闭了文档发布接口,用户无法使用Word,Windows Live Writer等工具来发布博客.使用Word写 ...
- GithubPage自定义腾讯404界面
思路来源 之前看到腾讯网络的404和github自带的404,反差很大,于是想自己弄一个了. 过程 github的404一点也不复杂,只是需要在根目录添加一个404.html的文档,或者404.md的 ...
- 【Cocos2d-x】Cocos2d-x跨Android平台搭建之四:Win7 64位+ eclipse + cocos2dX
开始研究cocos2dx,mark一下这个的配置步骤 1 下载eclipse 2 下载android sdk,配置sdk路径,添加环境变量 3 安装adt 4 下载android ndk,配 ...
- nginx中级应用-续
1.server下配置的每个location,都需要有自己的一套代理配置 即要么加入: root 某个目录 要么加入 proxy_pass 某个地址; proxy_redirect off; # ...
- [Windows] IIS7.5 部署ISAPI
环境: OS:Windows Server 2008 R2 Enterprise sp1 64位 IIS:7.5 ISAPI: delphi xe 编译的webbroker isapi dll 3 ...
- Nhibernate 存储过程获取返回值
写在前面:因为项目使用ssh.net所以做着做着要调用存储过程,而且是有返回值的,按照以前的做法直接在参数里指定下就可以获取,但是在nhibernate里调用就有点陌生了,百度一下得出的结果有两种:第 ...
- Ubuntu 网关服务器配置
1.设置Linux内核支持ip数据包的转发 echo "1" > /proc/sys/net/ipv4/ip_forward or vi /etc/sysctl.conf ...
- ref 和 out 的用法和区别以及params用法
方法参数可以划分为一下四种类型1 值参数:声明时不含任何修饰符2 引用参数:以ref修饰符声明3 输出参数:以out修饰符声明4 参数数组:以params修饰符声明 引用参数和输出参数不创建新的存储位 ...