微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

由于延迟 jquery-3.2.1.min.js,jQuery 依赖的 JS 文件正在中断

如何解决由于延迟 jquery-3.2.1.min.js,jQuery 依赖的 JS 文件正在中断

预先感谢您的帮助。

我正在尝试推迟加载 jquery-3.2.1.min.js 文件以修复渲染阻塞。所以,我尝试了以下方法

<script>
        window.addEventListener('DOMContentLoaded',(event) => {
            let script0 = document.createElement('script');
            let script1 = document.createElement('script');
            let script2 = document.createElement('script');
            let script3 = document.createElement('script');
            let script4 = document.createElement('script');
            let script5 = document.createElement('script');
            let script6 = document.createElement('script');
            let script7 = document.createElement('script');
            script0.src = "<?PHP echo BASE; ?>assets/plugins/owlcarousel/dist/owl.carousel.min.js";
            script1.src = "<?PHP echo BASE; ?>assets/plugins/vendors/bootstrap.bundle.min.js";
            script2.src = "<?PHP echo BASE; ?>assets/plugins/vendors/jquery.sparkline.min.js";
            script3.src = "<?PHP echo BASE; ?>assets/plugins/vendors/selectize.min.js";
            script4.src = "<?PHP echo BASE; ?>assets/js/core.js";
            script5.src = "<?PHP echo BASE; ?>assets/plugins/jquery-toast/js/jquery.toast.js";
            script6.src = "<?PHP echo BASE; ?>assets/js/process.js";
            script7.src = "<?PHP echo BASE; ?>assets/js/general.js";
            script0.defer = true;
            script1.defer = true;
            script2.defer = true;
            script3.defer = true;
            script4.defer = true;
            script5.defer = true;
            script6.defer = true;
            script7.defer = true;
            document.head.appendChild(script0);
            document.head.appendChild(script1);
            document.head.appendChild(script2);
            document.head.appendChild(script3);
            document.head.appendChild(script4);
            document.head.appendChild(script5);
            document.head.appendChild(script6);
            document.head.appendChild(script7);
        });
    </script>

而且效果很好!我知道这不是最好的代码,但确实有效。

现在,如果我将 jquery-3.2.1.min.js 推迟到:<script defer src="<?PHP echo BASE; ?>assets/plugins/vendors/jquery-3.2.1.min.js"></script>

... 依赖 jquery 的文件,还在不断崩溃。

调查,I read in several threads 在延迟的 JS 中,即使被延迟,也应该遵守顺序。但是,如果我不使用上面的代码,而是使用另一个代码,那么依赖于 jQuery 的 JS 也会中断:

    <script defer src="<?PHP echo BASE; ?>assets/plugins/vendors/jquery-3.2.1.min.js"></script>
    <script defer src="<?PHP echo BASE; ?>assets/plugins/owlcarousel/dist/owl.carousel.min.js"></script>
    <script defer src="<?PHP echo BASE; ?>assets/plugins/vendors/bootstrap.bundle.min.js"></script>
    <script defer src="<?PHP echo BASE; ?>assets/plugins/vendors/jquery.sparkline.min.js"></script>
    <script defer src="<?PHP echo BASE; ?>assets/plugins/vendors/selectize.min.js"></script>
    <script defer src="<?PHP echo BASE; ?>assets/js/core.js"></script>
    <!-- toast -->
    <script defer src="<?PHP echo BASE; ?>assets/plugins/jquery-toast/js/jquery.toast.js"></script>
    <!-- general JS -->
    <script defer src="<?PHP echo BASE; ?>assets/js/process.js"></script>
    <script defer src="<?PHP echo BASE; ?>assets/js/general.js"></script>

有什么指导吗?谢谢!!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?