老生常谈document.ready和window.onload

 更新时间:2024年01月03日 15:17:28   作者:前端路上的小兵  
这篇文章主要介绍了document.ready和window.onload的相关知识,包括document.ready和window.onload的区别,要使用document.ready()或者document.onload()的原因分析,本文结合实例代码给大家介绍的非常详细,需要的朋友参考下吧

1、对页面加载的认识

  一般情况下,一个页面的相应加载顺序是:域名解析——>加载html——>加载js和css——>加载图片等其他信息。

2、关于document.ready()

  执行时机:在DOM完全就绪时就可以被调用。
  多次使用:在同一个文件中多次使用,一次调用。
  理解:document.ready()的意思是在DOM加载完成之后执行ready()方法中的代码,换句话说,这个方法的本意是为了让代码的执行时间是在DOM加载完成之后才开始执行。

/*
  多次使用:运行结果为:先是one,然后是two
*/
function one(){
    alert("one");
}
function two(){
    alert("two");
}
$(document).ready(function(){
    one();
});
$(document).ready(function(){
    two();
});
/*
  写法
*/
//jq的写法
$(document).ready(function(){
    //do something
});
//简写,默认document
$().ready(function(){
    //do somethin
});
//简写
$(function(){
    //do something
});

3、关于document.onload()

  执行时机:在网页中所有元素(包括元素的所有关联文件)完全加载到浏览器后才执行,即JavaScript此时可以访问网页中的所有元素。
  多次执行:JavaScript的onload事件一次只能保存对一个函数的引用,他会自动调用最后面的函数覆盖前面的函数。

/*
  多次使用:运行结果为:只执行了two
*/
function one(){
    alert("one");
}
function two(){
    alert("two");
}
window.onload = one;
window.onload = two;
/*
  写法
*/
window.onload = function(){
    //do something
}
//等价于
$(window).load(function(){
    //do something
})

4、document.ready和window.onload的区别

  document.ready和window.onload的区别——JavaScript文档加载完成事件。
  页面加载完成有两种事件:
    一是ready,表示文档结构已经加载完成(不包含图片等非文字媒体文件)。
    二是onload,指示页面包含图片等文件在内的所有元素都加载完成。

5、为什么要使用document.ready()或者document.onload()

  $(document).ready() 里的代码是在页面内容都加载完才执行的,如果把代码直接写到script标签里,当页面加载完这个script标签就会执行里边的代码了,此时如果你标签里执行的代码调用了当前还没加载过来的代码或者dom,那么就会报错,当然如果你把script标签放到页面最后面那么就没问题了,此时和ready效果一样。

6、document.ready()的使用场景  

点击段落,此段落隐藏

<html>
<head>
    <meta charset="utf-8">
    <title>
        test
    </title>
    <script src="https://cdn.bootcss.com/jquery/1.10.2/jquery.min.js"></script>
    <script>
        $(document).ready(function () {
            $("p").click(function () {
                $(this).hide();
            });
        });
    </script>
</head>
<body>
    <p>If you click on me,I will disappear.</p>
</body>
</html>

  如果把$(document).ready(function(){});去掉后,无法隐藏段落

<html>
<head>
    <meta charset="utf-8">
    <title>
        test
    </title>
    <script src="https://cdn.bootcss.com/jquery/1.10.2/jquery.min.js"></script>
    <script>
        $("p").click(function () {
            $(this).hide();
        });
    </script>
</head>
<body>
    <p>If you click on me,I will disappear.</p>
</body>
</html>

  但是把script放到页面最后的话,就可恢复隐藏效果

<html>
<head>
    <meta charset="utf-8">
    <title>
        test
    </title>
    <script src="https://cdn.bootcss.com/jquery/1.10.2/jquery.min.js"></script>
</head>
<body>
    <p>If you click on me,I will disappear.</p>
    <script>
        $("p").click(function () {
            $(this).hide();
        });
    </script>
</body>
</html>  

到此这篇关于细说document.ready和window.onload的文章就介绍到这了,更多相关document.ready和window.onload内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解JS中Array对象扩展与String对象扩展

    详解JS中Array对象扩展与String对象扩展

    这篇文章主要介绍了详解JS中Array对象扩展与String对象扩展的相关资料,需要的朋友可以参考下
    2016-01-01
  • 全面解析Bootstrap手风琴效果

    全面解析Bootstrap手风琴效果

    这篇文章主要为大家详细介绍了全面解析Bootstrap手风琴效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2015-12-12
  • 使用 JavaScript 进行函数式编程 (一) 翻译

    使用 JavaScript 进行函数式编程 (一) 翻译

    本文是函数式编程系列的第一篇文章。这里我会简要介绍一下编程范式,然后会直接介绍使用 Javascript 进行函数式编程的概念,因为 JavsScript 是最被认可的函数式程序语言之一。我们鼓励读者通过参考资料部分进一步了解这一迷人的概念
    2015-10-10
  • js+css实现的简单易用兼容好的分页

    js+css实现的简单易用兼容好的分页

    使用html、js、css实现的简单易用兼容好的分页,具体的实现如下,感兴趣的朋友可以参考下
    2013-12-12
  • 你可能不需要在JavaScript使用switch语句

    你可能不需要在JavaScript使用switch语句

    这篇文章主要介绍了你可能不需要在JavaScript使用switch语句,对switch性能感兴趣的同学,可以参考下
    2021-04-04
  • JS实现点击表头表格自动排序(含数字、字符串、日期)

    JS实现点击表头表格自动排序(含数字、字符串、日期)

    这篇文章主要介绍了利用JS如何实现点击表头后表格自动排序,其中包含数字排序、字符串排序以及日期格式的排序,文中给出了完整的示例代码,相信对大家具有一定的参考价值,感兴趣的朋友们一起来看看吧。
    2017-01-01
  • JavaScript 读取元素的CSS信息的代码

    JavaScript 读取元素的CSS信息的代码

    在前端开发的工作中,总是会涉及到一些JavaScript和CSS信息交互的内容。
    2010-02-02
  • js实现简单的倒计时

    js实现简单的倒计时

    这篇文章主要为大家详细介绍了js实现简单的倒计时,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-01-01
  • 多个js与css文件的合并方法详细说明

    多个js与css文件的合并方法详细说明

    在Web项目的开发中,js,css文件会随着项目的开发变得越来越多,越来越大,这就给给性能方面带来一些问题;解决该问题的一个好的方法就是合并js,css文件需要了解的朋友可以参考下
    2012-12-12
  • element-ui 对话框dialog使用echarts报错'dom没有获取到'的问题

    element-ui 对话框dialog使用echarts报错'dom没有获取到'的问题

    这篇文章主要介绍了element-ui 对话框dialog里使用echarts,报错'dom没有获取到'的问题,在这个事件里边进行echarts的初始化,执行数据,本文结合实例代码给大家详细讲解,需要的朋友可以参考下
    2022-11-11

最新评论