您的位置:首页 > Web前端 > JavaScript

JavaScript学习笔记二十三:浏览器对象

2016-07-20 10:16 686 查看
JavaScript教程传送门

window

window
对象不但充当全局作用域,而且表示浏览器窗口。

window
对象有
innerWidth
innerHeight
属性,可以获取浏览器窗口的内部宽度和高度。内部宽高是指除去菜单栏、工具栏、边框等占位元素后,用于显示网页的净宽高。

兼容性:IE<=8不支持。

对应的,还有一个
outerWidth
outerHeight
属性,可以获取浏览器窗口的整个宽高。

navigator

navigator
对象表示浏览器的信息,最常用的属性包括:

navigator.appName:浏览器名称;

navigator.appVersion:浏览器版本;

navigator.language:浏览器设置的语言;

navigator.platform:操作系统类型;

navigator.userAgent:浏览器设定的
User-Agent
字符串。

navigator
的信息可以很容易地被用户修改,所以JavaScript读取的值不一定是正确的。很多初学者为了针对不同浏览器编写不同的代码,喜欢用
if
判断浏览器版本,例如:

var width;
if (getIEVersion(navigator.userAgent) < 9) {
width = document.body.clientWidth;
} else {
width = window.innerWidth;
}

// 正确的方法是充分利用JavaScript对不存在属性返回undefined的特性,直接用短路运算符||计算:
var width = window.innerWidth || document.body.clientWidth;


screen

screen
对象表示屏幕的信息,常用的属性有:

screen.width:屏幕宽度,以像素为单位;

screen.height:屏幕高度,以像素为单位;

screen.colorDepth:返回颜色位数,如8、16、24。

location

location
对象表示当前页面的URL信息。

//http://www.example.com:8080/path/index.html?a=1&b=2#TOP

location.protocol; // 'http'
location.host; // 'www.example.com'
location.port; // '8080'
location.pathname; // '/path/index.html'
location.search; // '?a=1&b=2'
location.hash; // 'TOP'


document

document
对象表示当前页面。由于HTML在浏览器中以DOM形式表示为树形结构,
document
对象就是整个DOM树的根节点。

document
对象提供的
getElementById()
getElementsByTagName()
可以按ID获得一个DOM节点和按Tag名称获得一组DOM节点。

document
对象还有一个
cookie
属性,可以获取当前页面的Cookie,而用户的登录信息通常也存在Cookie中,这就造成了巨大的安全隐患。为了解决这个问题,服务器在设置Cookie时可以使用
httpOnly
,设定了
httpOnly
的Cookie将不能被JavaScript读取。这个行为由浏览器实现,主流浏览器均支持
httpOnly
选项,IE从IE6 SP1开始支持。

为了确保安全,服务器端在设置Cookie时,应该始终坚持使用
httpOnly


history

history
对象保存了浏览器的历史记录,JavaScript可以调用
history
对象的
back()
forward ()
,相当于用户点击了浏览器的“后退”或“前进”按钮。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息