搜索
javascript - 无法获取js动态创建的元素的高度?
PHPz
PHPz 2017-04-10 16:31:56
[JavaScript讨论组]

我用两种方式创建p
1.种是用 document.createElement('p');
console.log($('p').height())有高度
2.种是用 $(body).html('<p></p>')
console.log($('p').height())没有高度
是不是前者刷新了dom树,后者没有刷新dom树

PHPz
PHPz

学习是最好的投资!

全部回复(3)
怪我咯

你的第一种方法没有把p添加到DOM里,例如$('body')appendChild(document.createElement('p'))
因此个人认为,console.log($('p').height())取到的不是你刚创建的元素,而是你之前就有的元素。
所以有高度。

怪我咯

你看下是不是你写的代码有问题
把代码贴出来看看
我这边测试是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('<p>123</p>');
            console.log($('p').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 p = document.createElement('p');
            document.body.appendChild(p);
        console.log($('p').height());*/

        $('body').html('<p></p>');
        console.log($('p').height());
    };
</script>
</html>

以上代码输出高度都为0

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号