javascript问题:window.onload问题
怪我咯
怪我咯 2017-04-10 14:53:30
[JavaScript讨论组]

问题:如果只写:

var one = document.getElementById('one');
one.onclick = function(){
    alert('你单击了这个p小方块');
}

如果只写上述代码为什么单击p小方块没作用呢。
为什么要使用window.onload才可以?
请讲解一下,谢谢。

<!DOCTYPE HTML>
<html>
    <head>
        <meta charset="UTF-8" />
        <style>
            p{
                width:100px;
                height:100px;
                border:1px solid black;
                background:#f00;
            }
        </style>
        <script>
            window.onload = function(){ 
                var one = document.getElementById('one');
                one.onclick = function(){
                    alert('你单击了这个p小方块');
                }
            }
        </script>
    </head>
    <body>
        <p id="one"></p>
    </body>
</html>
怪我咯
怪我咯

走同样的路,发现不同的人生

全部回复(1)
高洛峰

网页中的javaScript脚本代码往往需要在文档加载完成后才能够去执行,否则可能导致无法获取对象的情况,为了避免这种情况的发生,可以使用以下两种方式:
一.将脚本代码放在网页的低端,这样在运行脚本代码的时候,可以确保要操作的对象已经加载完成。
二.通过window.onload来执行脚本代码。

不添加window.onload, 当document.getElementById('one')时,id为one的dom元素还没有被创建。

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

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