我用两种方式创建div
1.种是用 document.createElement('div');
console.log($('div').height())有高度
2.种是用 $(body).html('<div></div>')
console.log($('div').height())没有高度
是不是前者刷新了dom树,后者没有刷新dom树
我用两种方式创建div
1.种是用 document.createElement('div');
console.log($('div').height())有高度
2.种是用 $(body).html('<div></div>')
console.log($('div').height())没有高度
是不是前者刷新了dom树,后者没有刷新dom树
你看下是不是你写的代码有问题
把代码贴出来看看
我这边测试是OK的
query append操作会将元素添加到当前DOM书上,渲染引擎在发现DOM有变化就会渲染页面(局部的或全局的)
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script src="../script/jquery-2.1.3.min.js"></script>
<script>
$(function(){
$('body').append('<div>123</div>');
console.log($('div').height());//有输出结果 18
});
</script>
</head>
<body>
</body>
</html>
经过测试,两种方法都可以获得元素高度。具体代码如下,你可以对照下看看
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
</body>
<script src="jquery.js"></script>
<script>
window.onload = function(){
/*var div = document.createElement('div');
document.body.appendChild(div);
console.log($('div').height());*/
$('body').html('<div></div>');
console.log($('div').height());
};
</script>
</html>
以上代码输出高度都为0
13 回答13k 阅读
7 回答2.2k 阅读
3 回答1.3k 阅读✓ 已解决
6 回答1.3k 阅读✓ 已解决
2 回答1.4k 阅读✓ 已解决
3 回答1.4k 阅读✓ 已解决
6 回答1.1k 阅读
你的第一种方法没有把div添加到DOM里,例如

$('body')appendChild(document.createElement('div'))
因此个人认为,
console.log($('div').height())
取到的不是你刚创建的元素,而是你之前就有的元素。所以有高度。