javascript - Jquery keydown 只能工作一次

标签 javascript jquery html

编辑:我通过将 = 更改为 == 来解决它,但这并没有完全解决它,但后来我对 $currentSlide 添加了更改,现在它可以工作了!耶!

            $(document).keydown(function(e) {
            if(e.keyCode == 39)
                {
                    if($currentSlide == $slide1){
                        slideShow(slide2);
                        $currentSlide = $slide2;
                    }
                    else if($currentSlide == $slide2){
                        slideShow(slide3);
                        $currentSlide = $slide3;
                    }
                    else if($currentSlide == $slide3){
                        slideShow(slide1);
                        $currentSlide = $slide1;
                    }
                }
        })

我已经搜索了答案,但没有找到任何适合我的问题的内容。我是 javascript 新手,所以请耐心等待。

我有一个可以用作幻灯片的功能。 (我在 jquery 变量前面使用 $,我也有很多 javascript 变量,所以我只是用它来分隔它们。)

var $currentSlide = "#slide1";
var $slide1 = "#slide1";
var $slide2 = "#slide2";
var $slide3 = "#slide3";

function slideShow($slide) {
    if ($slide != $currentSlide){
        $($currentSlide).fadeOut(500);
        $($slide).delay(500).fadeIn(500);
        $currentSlide = $slide;
    }
};

为了调用此函数,我使用了一个带有参数的简单链接,具体取决于哪张幻灯片处于事件状态。

onclick="slideShow(slide2)"

然后我想通过按键(向右)更改幻灯片。这是我的按键代码:

$(document).keydown(function(e) {
    if(e.keyCode == 39) {
        if ($currentSlide = $slide1){
            slideShow(slide2);
        } else if($currentSlide = $slide2) {
            slideShow(slide3);
        } else if($currentSlide = $slide3) {
            slideShow(slide1);
        }
     }
})

使用链接时它工作得很好,但是当我按下键时它的行为非常奇怪。第一次点击就像一个魅力,但之后就不再起作用了。如果我单击获取第三张幻灯片,再次单击会将下一张幻灯片放在幻灯片 3 的顶部,但幻灯片 3 永远不会消失。

我意识到我在这里犯了一些巨大的错误,但我还是一个初学者,无法修复它。有任何想法吗?

最佳答案

您的 if-else 条件将始终为 true,因为您使用了“=”而不是“==”。因为你的第一个 if 条件为真,所以它总是显示幻灯片2,并且在你看来它只工作了一次

$(document).keydown(function(e) {
    if(e.keyCode == 39) {
        if ($currentSlide == $slide1){
            slideShow(slide2);
        } else if($currentSlide == $slide2) {
            slideShow(slide3);
        } else if($currentSlide == $slide3) {
            slideShow(slide1);
        }
     }
})

如果您使用的是幻灯片,第二个问题可能是由幻灯片上的时钟引起的。当您单击下一个/上一个按钮时,您需要重置幻灯片的时钟。

关于javascript - Jquery keydown 只能工作一次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41223997/

相关文章:

javascript - 如何在不使用 css 转换的情况下将 jQuery animate 与 css3 属性结合起来?

javascript - 单击链接行为不一致

ipad 上的 jQuery Slimscroll

jquery - 如果该行的第一个单元格包含大于 50 且小于 100 的值,则使用 jquery 删除该行?

javascript - 在网络浏览器中滥用伪造的用户输入

php - 一个 HTML 表格中的多个表单

javascript - onpaste 事件替换文本框中的文本

javascript - Switch 函数运行但大小写被忽略

jquery - 适用于 Chrome,但不适用于 Firefox - jquery

javascript - 如何使用 Javascript 单击 anchor 标记(没有 ID 或类)