window

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

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

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

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信息。例如,一个完整的URL:

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

可以用location.href获取。要获得URL各个部分的值,可以这么写:

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' 

要加载一个新页面,可以调用location.assign()。如果要重新加载当前页面,调用location.reload()方法非常方便。

转载于:https://www.cnblogs.com/EganZhang/p/6538518.html

windownavigatorscreenlocation相关推荐

最新文章

  1. 关于运维体系谈谈我的想法
  2. python算两个点的距离公式_计算Python Numpy向量之间的欧氏距离实例
  3. Scala _02基础
  4. mac中安装activeMQ
  5. 交叉渡线道岔规格_交叉渡线铁路道岔的型号及选用
  6. 判断文件是否损坏_Bash技巧:把变量赋值为换行符,判断文件是否以换行符结尾...
  7. mysqli 语句和mysql语句一样吗_mysqli语句的用法
  8. centos----tftpd配置
  9. ERP系统成本计算方法大揭秘?
  10. 中国移动科普:为什么手机移动网络要叫 “蜂窝移动网络”
  11. 高数篇:03罗尔定理
  12. 【翻译】CSPNet: A New Backbone that can Enhance Learning Capability of CNN
  13. 2.SSM之Spring整合、AOP及Spring事务
  14. 网站快速成型工具-Element UI
  15. 【archlinux】安装系统
  16. 项目场景-------滚动条横向竖向同步滚动
  17. 基于Scrapy的链家二手房爬虫
  18. 链克迎来大涨?迅雷:这只是前戏,“王炸”还在后头呢!
  19. @value()注解
  20. ubuntu中对于大小写锁定键的控制

热门文章

  1. Windows Mobile 5.0新增API介绍(转自MSDN)
  2. 云南大学软件测试,软件测试大赛云南省省赛在软件学院如期举行
  3. arp 原理及查杀方式
  4. 转:WCF基础知识问与答
  5. JSP基于JDBC操作MSSQL2008数据库
  6. iproute2 对决 net-tools
  7. 热门用户推荐能否支持分类筛选?
  8. ASP.NET——C#文件夹创建与文件存在判断
  9. ArcGIS Pro快速汉化方法
  10. 10大Go语言开源项目推荐