我想写一个JavaScript碰撞效果,但是获取documentElement.clientWidth总报错,怎么解决?

<!DOCTYPEhtml><html><head><styletype='text/css'>#div1{height:80px;width:80px;backgrou... <!DOCTYPE html>
<html>
<head>
<style type='text/css'>

#div1{height:80px;width:80px;background:red;position:absolute;}
</style>
<script>
window.onload=function(){
var oBtn=document.getElementById("button");
oBtn.onclick=function(){
startMove();
}
}
var iSpeedX=6;
var iSpeedY=20;
function startMove(){
setInterval(function(){
var oDiv = document.getElementById("div1");
console.log(oDiv.documentElement);
var l=oDiv.offsetLeft+iSpeedX;
var h=oDiv.offsetHeight+iSpeedY;
if(l>oDiv.documentElement.clientWidth-oDiv.offsetWidth){
iSpeedX*=-0.8;

}
if(h>oDiv.documentElement.clientHeight-oDiv.offsetHeight){
iSpeedY*=-0.8;
}
},30);

}
</script>
</head>
<body>
<input type="button" id="button" value="点击"/>
<div id="div1"></div>
</body>
</html>
展开
 我来答
灰常了dei
2015-06-29 · TA获得超过1736个赞
知道小有建树答主
回答量:596
采纳率:60%
帮助的人:628万
展开全部
如果你是获取可视区域的宽度是
document.documentElement.clientWidth || document.body.clientWidth (兼容写法)
如何你是获取div的宽度应该是
oDiv.offsetWidth
你这个oDiv.documentElement.clientWidth表述是错误的
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式