浅谈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圆角插件
Oct 26 Javascript
js 如何实现对数据库的增删改查
Nov 23 Javascript
推荐4个原生javascript常用的函数
Jan 12 Javascript
jQuery监控文本框事件并作相应处理的方法
Apr 16 Javascript
AngularJS中的过滤器filter用法完全解析
Apr 22 Javascript
Bootstrap面板使用方法
Jan 16 Javascript
详解微信小程序入门五: wxml文件引用、模版、生命周期
Jan 20 Javascript
Angular2 自定义validators的实现方法
Jul 05 Javascript
javascript实现获取一个日期段内每天不同的价格(计算入住总价格)
Feb 05 Javascript
echarts实现词云自定义形状的示例代码
Feb 20 Javascript
JS实现导航栏楼层特效
Jan 01 Javascript
Vue3 的响应式和以前有什么区别,Proxy 无敌?
May 20 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的输入输出流
2007/02/14 PHP
php cache类代码(php数据缓存类)
2010/04/15 PHP
simplehtmldom Doc api帮助文档
2012/03/26 PHP
PHP utf-8编码问题,utf8编码,数据库乱码,页面显示输出乱码
2013/04/08 PHP
php获取英文姓名首字母的方法
2015/07/13 PHP
php使用pclzip类实现文件压缩的方法(附pclzip类下载地址)
2016/04/30 PHP
jQuery源码分析-01总体架构分析
2011/11/14 Javascript
js Html结构转字符串形式显示代码
2011/11/15 Javascript
js查找某元素中的所有图片地址的方法
2014/01/16 Javascript
js读取cookie方法总结
2014/10/31 Javascript
js实现的动画导航菜单效果代码
2015/09/10 Javascript
Bootstrap每天必学之前端开发框架
2015/11/19 Javascript
jQuery实现监控页面所有ajax请求的方法
2015/12/10 Javascript
javascript DIV实现跟随鼠标移动
2020/03/19 Javascript
基于Bootstrap和jQuery构建前端分页工具实例代码
2016/11/23 Javascript
微信小程序 商城开发(ecshop )简单实例
2017/04/07 Javascript
Angular2仿照微信UI实现9张图片上传和预览的示例代码
2017/10/19 Javascript
vue.js开发实现全局调用的MessageBox组件实例代码
2017/11/22 Javascript
详解angular2 控制视图的封装模式
2018/12/27 Javascript
[01:52]深扒TI7聊天轮盘语音出处7
2017/05/11 DOTA
Python爬虫之模拟知乎登录的方法教程
2017/05/25 Python
python如何读写json数据
2018/03/21 Python
python对list中的每个元素进行某种操作的方法
2018/06/29 Python
python 设置输出图像的像素大小方法
2019/07/04 Python
Python数据可视化:幂律分布实例详解
2019/12/07 Python
详解matplotlib绘图样式(style)初探
2021/02/03 Python
亚马逊海外购:亚马逊美国、英国、日本、德国直邮
2021/03/18 全球购物
优秀生推荐信范文
2013/11/28 职场文书
幼儿园托班开学寄语
2014/01/18 职场文书
草船借箭教学反思
2014/02/03 职场文书
教师先进个人材料
2014/12/17 职场文书
先进典型发言材料
2014/12/30 职场文书
对公司的意见和建议
2015/06/04 职场文书
爱国电影观后感
2015/06/19 职场文书
Go遍历struct,map,slice的实现
2021/06/13 Golang
python的列表生成式,生成器和generator对象你了解吗
2022/03/16 Python