首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将脚本重写到jQuery 3

将脚本重写到jQuery 3
EN

Stack Overflow用户
提问于 2017-01-16 09:12:56
回答 2查看 60关注 0票数 1

在我的网站上,我使用以下代码。它在jQuery 2.2.3中运行得很好。现在我想使用jQuery 3,但它似乎不起作用。你能帮我把这段代码重写成jQuery 3吗?香草js解决方案也将不胜感激。

代码语言:javascript
复制
$(document).ready(function () {
    $('#preloading').load("loading.html", function () {
        $(window).load(function () {
            $('#preloading').fadeOut('slow');
        });
    });
});
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-01-16 09:15:43

您的问题在于,在jQuery 3.x中,load()方法仅用于通过AJAX请求检索内容,因此使用它作为事件处理程序是无效的。顺便提一下--在您使用2.x的原始代码中不需要它。

要解决这个问题,只需删除$(window).load()调用:

代码语言:javascript
复制
$(document).ready(function () {
    $('#preloading').load("loading.html", function() {
        $('#preloading').fadeOut('slow');
    });
});
票数 0
EN

Stack Overflow用户

发布于 2017-05-31 09:33:37

Lucas,您的代码已经废弃/删除了方法:

  1. 被否决的$(document).ready (https://jquery.com/upgrade-guide/3.0/#deprecated-document-ready-handlers-other-than-jquery-function)
  2. 移除.load() (https://jquery.com/upgrade-guide/3.0/#breaking-change-load-unload-and-error-removed)

替换后:

代码语言:javascript
复制
$(function () {
    $('#preloading').load("loading.html", function () {
        $(window).on('load', function () {
            $('#preloading').fadeOut('slow');
        });
    });
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41672826

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档