JavaScript学习笔记二十三:浏览器对象
2016-07-20 10:16
686 查看
JavaScript教程传送门
兼容性:IE<=8不支持。
对应的,还有一个
navigator.appName:浏览器名称;
navigator.appVersion:浏览器版本;
navigator.language:浏览器设置的语言;
navigator.platform:操作系统类型;
navigator.userAgent:浏览器设定的
screen.width:屏幕宽度,以像素为单位;
screen.height:屏幕高度,以像素为单位;
screen.colorDepth:返回颜色位数,如8、16、24。
用
为了确保安全,服务器端在设置Cookie时,应该始终坚持使用
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 (),相当于用户点击了浏览器的“后退”或“前进”按钮。
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android Manifest 用法
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- Python动态类型的学习---引用的理解
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 回顾 Firefox 历史
- 小白观察:微软释放出其基于 Chromium 的 Edge 浏览器
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)