Easyslider 的 JavaScript 问题

发布于 2024-10-12 05:32:50 字数 536 浏览 3 评论 0原文

首先访问此页面并将鼠标悬停在菜单上: http://milabalami.com/saved/2/index.php

然后访问此Wordpress我在其中实现了完全相同的代码的页面: http://milabalami.com

当您将鼠标悬停在 Wordpress 菜单上时,您会看到滑块没有显示。为什么?我可以看到该页面给出了一条错误消息:

$ is not a function 
http://miladalami.com/wp-content/themes/sandbox/js/custom.js

为什么会这样?它与在其他页面上完美运行的代码完全相同。我不明白为什么它在 WordPress 页面上给出该错误,而不是在滑块工作的另一个页面上给出该错误。谁能帮我解决这个难题?

蒋易解开了谜题。

First visit this page and hover your mouse over the menu:
http://milabalami.com/saved/2/index.php

Then visit this Wordpress page where I have implemented the exact same code:
http://milabalami.com

When you hover your mouse over the Wordpress menu, you will see that the slider does not show up. Why? I can see that the page gives an error stating:

$ is not a function 
http://miladalami.com/wp-content/themes/sandbox/js/custom.js

Why is that? Its the exact same code that worked perfectly on the other page. I dont understand why it is giving that error on the Wordpress page, and not on the other one where the slider works. Anyone that could assist me in solving this puzzle?

Puzzle solved by Yi Jiang.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

夏天碎花小短裙 2024-10-19 05:32:50

看起来好像在这个过程中的某个地方,$ 被覆盖了。不过,您仍然可以使用您的代码,只需使用 jQuery 而不是 $ -

jQuery(document).ready(function($) {
    $("#featured").easySlider({
        speed: 400
    });

    $("#menu ul li a[class!='current']")
    .css( {backgroundPosition: "200px 2px"} )
    .mouseover(function(){
        $(this).stop().animate({backgroundPosition:"(0 2px)"}, {duration:400})
    })
    .mouseout(function(){
        $(this).stop().animate({backgroundPosition:"(200px 2px)"}, {duration:400})
    })
});

不过,这是一种权宜之计。您应该将所有代码合并到一个文件中,而不是像现在一样将它们分开,并减少对插件的依赖。

It looks like somewhere along the way, the $ got overridden. You can still use your code, however, by using jQuery instead of $ -

jQuery(document).ready(function($) {
    $("#featured").easySlider({
        speed: 400
    });

    $("#menu ul li a[class!='current']")
    .css( {backgroundPosition: "200px 2px"} )
    .mouseover(function(){
        $(this).stop().animate({backgroundPosition:"(0 2px)"}, {duration:400})
    })
    .mouseout(function(){
        $(this).stop().animate({backgroundPosition:"(200px 2px)"}, {duration:400})
    })
});

It's a stopgap measure, however. You should combine all your code into a single file, instead of separating them out like they are right now, and reduce your dependency on plugins.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文