浅谈JavaScript的innerWidth与innerHeight


Posted in Javascript onOctober 12, 2017

innerWidth与innerHeight属性

说明:window对象的只读属性,声明了窗口的文档显示区的高度和宽度,以像素(px)为计量单位。 (注意:这里的宽度和高度不包括菜单栏、工具栏以及滚动条等的高度)

下面便对这两个属性进行验证:

屏幕分辨率为:1920x1080 浏览器:QQ浏览器(内核是Chrome) 代码如下:

var width=window.innerWidth,height=window.innerHeight; //分别定义width和height接收窗口的高和宽

alert(width); //窗口的宽度 1920px

alert(height);

//窗口的高度 950px

innerWidth因为浏览器两旁没有遮挡物,所以完美的得到了屏幕的宽度1920,而innerHeight因为浏览器上面有工具栏,显示屏又有任务栏,所以被挤掉了130px

这次博主依次干掉了任务栏(其实就是隐藏了)和工具栏中的标签页 并按下F12加上了开发者选项 再次进行测试:

/*————————干掉任务栏后————————*/
  var width=window.innerWidth,height=window.innerHeight;  
  alert(width);  //宽度没有变化,还是1920px
  alert(height); //而窗口的高度990px,表明任务栏占40px(任务栏的默认高度) 导致没有获取到全部高度

  /*————————又干掉标签页后,并加上开发者选项后————————*/
  var width=window.innerWidth,height=window.innerHeight;
  alert(width);  //1381px,说明浏览器开发者选项,对innerWidth有影响 1920-1381=549px 
  alert(height); 
//而窗口的高度979px,任务栏占40px,标签页占了11px(990-979) 而由此得出剩下的工具栏占了1080-979=101px

结论:说明innerHeight和innerWidth确实只计算显示窗口像素,如果没有菜单栏、工具栏等外部因素挤压它,它就会自动延伸,而如果有就只按显示窗体走

测试完外部的因素,下面测试一下内部的因素滚动条

<html>
  <head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    
  <title>测试innerHeight属性</title>
   
  </head>
  
  <body>
  <div style="width:500px;height:1300px;background-color:red;"></div>
  
  <script>  
    window.onload=function(){
     /*————————div超出长度,带着滚动条后————————*/
     var width=window.innerWidth,height=window.innerHeight;  
      alert(width);  //窗口的宽度 1920px
      alert(height); //窗口的高度 950px
   }
   </script>
  </body>


 </html>

结论:说明内部的滚动条对innerWidth并没有影响,即使存在对width也没有影响,依旧是1920px

最终结论:innerHeight和innerWidth获取的是窗体的高与宽,外部因素如(浏览器开发者选项,收藏夹)会对它有影响,而内部因素(滚动条)则对其没有影响

下面说一下槽点最多的IE,关于IE兼容性的问题,可以这样解决

//兼容代码可以这样子写
var width = window.innerWidth,height = window.innerHeight;

if (typeof width != 'number') {  //如果类型不为number,表示该浏览器不支持innerWidth属性

 if (document.compatMode == 'CSS1Compat') {   //CSS1Compat:判断是否为标准兼容模式。

  width = document.documentElement.clientWidth;

  height = document.docuementElement.clientHeight;

 } else { //不是标准模式,则有可能是IE6或及其以下版本(早期的浏览器对css进行解析时,并未遵守W3C标准)

  width = document.body.clientWidth;   //网页可见区域宽

  height = document.body.clientHeight;   //网页可见区域高
}
  alert(width);
  alert(height);

以上这篇浅谈JavaScript的innerWidth与innerHeight就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
基于JQuery实现相同内容合并单元格的代码
Jan 12 Javascript
javascipt基础内容--需要注意的细节
Apr 10 Javascript
计算新浪Weibo消息长度(还可以输入119字)
Jul 02 Javascript
详解JavaScript中的表单验证
Jun 16 Javascript
Javascript编程之继承实例汇总
Nov 28 Javascript
ionic进入多级目录后隐藏底部导航栏(tabs)的完美解决方案
Nov 23 Javascript
使用jQuery的ajax方法向服务器发出get和post请求的方法
Jan 13 Javascript
jQuery中Chosen三级联动功能实例代码
Mar 07 Javascript
深入理解vue-router之keep-alive
Aug 31 Javascript
vue插件开发之使用pdf.js实现手机端在线预览pdf文档的方法
Jul 12 Javascript
apicloud拉起小程序并传递参数的方法示例
Nov 21 Javascript
C#程序员入门学习微信小程序的笔记
Mar 05 Javascript
原生JS封装animate运动框架的实例
Oct 12 #Javascript
javascript中神奇的 Date对象小结
Oct 12 #Javascript
详解使用路由延迟加载 Angular 模块
Oct 12 #Javascript
ionic3+Angular4实现接口请求及本地json文件读取示例
Oct 11 #Javascript
js实现单张图片平移切换效果
Oct 11 #Javascript
jQuery自动或手动图片切换效果
Oct 11 #jQuery
简单实现vue验证码60秒倒计时功能
Oct 11 #Javascript
You might like
通用PHP动态生成静态HTML网页的代码
2010/03/04 PHP
PHP数组无限分级数据的层级化处理代码
2012/12/29 PHP
php读取mysql中文数据出现乱码的解决方法
2013/08/16 PHP
PHP获取数组的键与值方法小结
2015/06/13 PHP
php实现源代码加密的方法
2015/07/11 PHP
php生成图片验证码的实例讲解
2015/08/03 PHP
thinkphp修改配置进入默认首页的方法
2017/02/07 PHP
javascript Firefox与IE 替换节点的方法
2010/02/24 Javascript
各种页面定时跳转(倒计时跳转)代码总结
2013/10/24 Javascript
JavaScript控制网页平滑滚动到指定元素位置的方法
2015/04/17 Javascript
Javascript验证Visa和MasterCard信用卡号的方法
2015/07/27 Javascript
jQuery实现平滑滚动的标签分栏切换效果
2015/08/28 Javascript
利用CSS、JavaScript及Ajax实现图片预加载的三大方法
2017/01/22 Javascript
vue 2.0项目中如何引入element-ui详解
2017/09/06 Javascript
JS监控关闭浏览器操作的实例详解
2017/09/12 Javascript
详解微信小程序之提高应用速度小技巧
2020/01/07 Javascript
jquery实现有过渡效果的tab切换
2020/07/17 jQuery
Vue用mixin合并重复代码的实现
2020/11/27 Vue.js
jQuery实现简单轮播图效果
2020/12/27 jQuery
[02:57]2014DOTA2国际邀请赛 选手辛苦解说更辛苦
2014/07/10 DOTA
[00:57]林俊杰助阵DOTA2亚洲邀请赛
2015/01/28 DOTA
TensorFlow saver指定变量的存取
2018/03/10 Python
Python Tornado之跨域请求与Options请求方式
2020/03/28 Python
Python代码执行时间测量模块timeit用法解析
2020/07/01 Python
python中doctest库实例用法
2020/12/31 Python
Django中template for如何使用方法
2021/01/31 Python
办公室文秘自我鉴定
2013/09/21 职场文书
机械设计及其自动化专业推荐信
2013/10/31 职场文书
中学教师请假制度
2014/02/03 职场文书
幼儿园毕业园长感言
2014/02/24 职场文书
党的群众路线教育实践活动学习心得体会
2014/03/03 职场文书
学雷锋月活动总结
2014/04/25 职场文书
党员领导干部民主生活会批评与自我批评发言
2014/09/28 职场文书
给上级领导的感谢信
2015/01/22 职场文书
企业财务人员岗位职责
2015/04/14 职场文书
教你用Python写一个植物大战僵尸小游戏
2021/04/25 Python