jQuery 更新为v3.0.0
.
jquery.js:9612 Uncaught TypeError: url.indexOf is not a function
任何想法为什么?
更新所有调用load
函数的代码,例如,
$(window).load(function() { ... });
至
$(window).on('load', function() { ... });
jquery.js:9612 Uncaught TypeError: url.indexOf 不是函数
此错误消息来自jQuery.fn.load
函数。
我在我的应用程序中遇到了同样的问题。经过一番挖掘,我在jQuery 博客中找到了这个语句,
自 jQuery 1.8 起已弃用的 .load、.unload 和 .error 不再是. 使用 .on() 注册监听器。
我只是简单地改变我的 jQuery 对象调用上述load
函数的方式。一切都按预期工作。
更好的方法可能是这样的 polyfill
jQuery.fn.load = function(callback){ $(window).on("load", callback) };
有了这个,您可以保持遗留代码不变。如果你使用 webpack,一定要使用 script-loader。
Jquery 3.0 有一些重大更改,由于冲突而删除了某些方法。您的错误很可能是由于这些更改之一,例如删除 .load() 事件。
要解决此问题,您需要重写代码以与 Jquery 3.0 兼容,或者您可以使用JQuery Migrate 插件来恢复已弃用和/或删除的 API 和行为。
更新到最新版本的 JQuery 后,我遇到了同样的错误。因此,我更新了我正在处理的 jquery 文件,如上一个答案所述,所以它说.on("load")
而不是.load()
.
此修复程序不是很稳定,有时对我不起作用。因此,要解决此问题,您应该从以下位置更新您的代码:
.load();
至
.trigger("load");
我从以下来源得到了这个修复:https ://github.com/stevenwanderski/bxslider-4/pull/1024
@choz 答案是正确的方法。如果您有很多用途并希望确保它在任何地方都能正常工作而无需更改,您可以添加这些小的迁移片段:
/* Migration jQuery from 1.8 to 3.x */
jQuery.fn.load = function (callback) {
var el = $(this);
el.on('load', callback);
return el;
};
在这种情况下,您在其他节点上没有错误,例如$image
@Korsmakolnikov 回答中的错误!
const $image = $('img.image').load(function() {
$(this).doSomething();
});
$image.doSomethingElseWithTheImage();