新手关于JS如何获取屏幕当前长宽的问题

如题,本人JS新手,想用Canvas画一幅图。

var div1 = document.getElementById("div1");
var canv1 = document.createElement("canvas");
div1.appendChild(canv1);

然后,为了是Canvas位于屏幕中心,需要获取屏幕长宽,百度得到的结果都说用

document.documentElement.clientHeight;

document.documentElement.clientWidth;

然而实际产生的结果是,div元素正确获得了当前窗口的宽度,但是高度却为0!

我又尝试了offsetHeight,但最终高度依然为0。而window.screen.height却可以正常获取屏幕高度。然而屏幕高度与窗口高度毕竟存在区别,我不想在这里妥协。

经过更多的百度,我终于明白,原来在IE9以前,document.documentElement.clientHeight;是有效的,然而到了IE9以后,以及其他主流浏览器如Chrome,firefox则是不支持的,它们有了新的语句

window.innerHeight;

window.innerWidth;

经过尝试,没有任何问题,js正确获得了窗口长宽。

所以说,即便是很简单的语句,也有可能随着更新换代而产生改变。当你熟悉的代码不管用时,记得看看版本。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值