myReady的写法

myReady的写法

老师好,怎么跟window.onload不一样?window.onload=function{ }再放入代码,这里myReady(function(){})这样写的逻辑关系是什么,貌似课程也没详细讲解,望讲解一下

正在回答 回答被采纳积分+1

登陆购买课程后可参与讨论,去登陆

2回答
好帮手慕糖 2020-03-30 19:05:10

同学你好,如下,就是这个文件中的代码,有添加注释,同学可以参考下。

function myReady(fn){
    //对于现代浏览器,对DOMContentLoaded事件的处理采用标准的事件绑定方式
    if ( document.addEventListener ) {
        document.addEventListener("DOMContentLoaded", fn, false);
    } else {
        IEContentLoaded(fn);
    }
    //IE模拟DOMContentLoaded
    function IEContentLoaded (fn) {
        var d = window.document;
        var done = false;
        //只执行一次用户的回调函数init()
        var init = function () {
            if (!done) {
                done = true;
                fn();
            }
        };
        (function () {
            try {
                // DOM树未创建完之前调用doScroll会抛出错误
                d.documentElement.doScroll('left');
            } catch (e) {
                //延迟再试一次~
                setTimeout(arguments.callee, 50);
                return;
            }
            // 没有错误就表示DOM树创建完毕,然后立马执行用户回调
            init();
        })();
        //监听document的加载状态
        d.onreadystatechange = function() {
            // 如果用户是在domReady之后绑定的函数,就立马执行
            if (d.readyState == 'complete') {
                d.onreadystatechange = null;
                init();
            }
        }
    }
}

不过,里面涉及了很多高级阶段才学的内容 。简单了解一下即可,不需要深入研究。

祝学习愉快~

好帮手慕糖 2020-03-30 13:55:28

同学你好,关于你的问题,回答如下:

1、当把js代码放在head中,代码顺序执行,当页面在浏览器中打开时,会先执行js代码,再执行body里面的dom结构。如果js执行时要获取body中的元素,那么就会报错,因为页面的结构还没有加载进来。所以老师为了解决这个问题,写了一个方法:

在domReady.js中, 老师封装了一个myReady方法 , 这个方法实现的效果就是$(document).ready(function(){}) , 让DOM加载完后再去执行js代码 。因为现在还没有学习到jQuery , 所以这里老师为了方便课程讲解自己封装了一个类似的方法,里面涉及了很多高级阶段才学的内容 。同学对 domReady.js简单了解一下即可,不需要深入研究,先用老师的写好的就行。后期学了jQuery,使用$(document).ready(function(){}) 就可以啦 。

2、和window.onload加载事件有些类似,但是window.onload事件加载的更全面一些,包括dom结构,图片以及其他资源等。而封装这个只是DOM加载完之后就会触发这个事件,不需要等待图片和其他资源加载完毕。

如果我的回答帮助了你,欢迎采纳,祝学习愉快!

  • 提问者 慕雪9296518 #1
    明白,但我想问的是myReady(function(){})这个语法的逻辑是怎么理解的,就想wind.onload是先触发on.load事件再绑定这个函数,那这个myReady(function(){})语法又是怎么理解的
    2020-03-30 14:56:59
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师