浅谈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 autocomplate 自扩展插件、自动完成示例代码
Mar 28 Javascript
jQuery随便控制任意div隐藏的方法
Jun 28 Javascript
json数据的列循环示例
Sep 06 Javascript
阿里巴巴技术文章分享 Javascript继承机制的实现
Jan 14 Javascript
vue实现可增删查改的成绩单
Oct 27 Javascript
jQuery实现鼠标悬停3d菜单展开动画效果
Jan 19 Javascript
JS/HTML5游戏常用算法之碰撞检测 像素检测算法实例详解
Dec 12 Javascript
vue中各种通信传值方式总结
Feb 14 Javascript
JS前端知识点offset,scroll,client,冒泡,事件对象的应用整理总结
Jun 27 Javascript
JavaScript通如何过RGraph实现动态仪表盘
Oct 15 Javascript
详解vue-router的导航钩子(导航守卫)
Nov 02 Javascript
了不起的11个JavaScript代码重构最佳实践小结
Jan 11 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 SEO优化之URL优化方法
2011/04/21 PHP
PHP判断远程图片是否存在的几种方法
2014/05/04 PHP
php中二维数组排序问题方法详解
2015/08/28 PHP
PHP实现生成带背景的图形验证码功能
2016/10/03 PHP
php根据数据id自动生成编号的实现方法
2016/10/16 PHP
PHP使用ActiveMQ实例
2018/02/05 PHP
Javascript实例教程(19) 使用HoTMetal(5)
2006/12/23 Javascript
jquery隔行换色效果实现方法
2015/01/15 Javascript
D3.js中data(), enter() 和 exit()的问题详解
2015/08/17 Javascript
提升jQuery的性能需要做好七件事
2016/01/11 Javascript
jQuery实现鼠标经过显示动画边框特效
2017/03/24 jQuery
原生javascript上传图片带进度条【实例分享】
2017/04/06 Javascript
angularjs中使用ng-bind-html和ng-include的实例
2017/04/28 Javascript
JS获取字符对应的ASCII码实例
2017/09/10 Javascript
JQuery使用属性addClass、removeClass和toggleClass实现增加和删除类操作示例
2019/11/18 jQuery
在博客园博文中添加自定义右键菜单的方法详解
2020/02/05 Javascript
mpvue 项目初始化及实现授权登录的实现方法
2020/07/20 Javascript
可拖拽组件slider.js使用方法详解
2020/12/04 Javascript
[09:23]国际邀请赛采访专栏:iG战队VK,Tongfu战队Cu
2013/08/05 DOTA
Python实现多行注释的另类方法
2014/08/22 Python
Python时间获取及转换知识汇总
2017/01/11 Python
python爬虫入门教程--快速理解HTTP协议(一)
2017/05/25 Python
Python实现查看系统启动项功能示例
2018/05/10 Python
Python系统监控模块psutil功能与经典用法分析
2018/05/24 Python
Python多线程应用于自动化测试操作示例
2018/12/06 Python
python SVM 线性分类模型的实现
2019/07/19 Python
使用 Supervisor 监控 Python3 进程方式
2019/12/05 Python
实习医生自我评价
2013/09/22 职场文书
高中毕业的自我鉴定
2013/12/09 职场文书
青年创业培训欢迎词
2014/01/08 职场文书
预备党员入党自我评价范文
2014/03/10 职场文书
毕业晚会主持词
2014/03/24 职场文书
优秀团员自我评价范文
2014/04/23 职场文书
植树造林的宣传标语
2014/06/23 职场文书
户籍证明模板
2014/09/28 职场文书
给女朋友的道歉短信
2015/05/12 职场文书