javascript - 使用鼠标位置在网页上滚动 - 将鼠标悬停在侧面元素上

标签 javascript jquery html css

所以我这里有这个布局。

<div class="content">
    <div class="direction_left"></div>
    <div class="direction_right"></div>
    <div class="direction_up"></div>
    <div class="direction_down"></div>
</div>
<div id="game">
    <div id="pos"></div>
</div>

4 div,如果我悬停在顶部它(应该)滚动到顶部,如果我悬停在底部它(应该)滚动机器人,向左滚动向左,向右滚动向右!


将鼠标悬停在内容内的四个 div 中的任何一个上时,页面将相应地滚动。

重要 h_amount 是水平的,v_amount 是垂直的

function scroll_h() {
    console.log('scrolling left and right'+h_amount);
    $('#game').animate({
        scrollLeft: h_amount
    }, 100, 'linear',function() {
        if (h_amount != '') {
            scroll_h();
        }
    });
}
function scroll_v() {
    console.log('scrolling up and down'+v_amount);
    $('#game').animate({
        scrollTop: v_amount
    }, 100, 'linear',function() {
        if (v_amount != '') {
            scroll_v();
        }
    });
}

然后在悬停时调用

$('.direction_right').hover(function() {
    console.log('scroll right');
    h_amount = '+=50';
    scroll_h();
}, function() {
    h_amount = '';
});

$('.direction_up').hover(function() {
    console.log('scroll up');
    v_amount = '-=50';
    scroll_v();
}, function() {
    v_amount = '';
});

FULL fiddle here

问题,我不明白为什么它对上下不起作用。我认为我的脚本是正确的,所以我想也许 css 是我的一个普遍弱点可能是错误的 :D 帮助!

最佳答案

我想我找到了答案,如果我错了请纠正我!

找到这个问题 here这问为什么他的 scrollTop() 不会动画,答案说窗口没有 scrollTop() 属性,并使用 bodyhtml 代替(取决于浏览器,因此请同时使用两者)。 因此我认为我的 #game div 也没有 scrollTop() 属性!所以我用 html,body 替换了它,它现在可以工作了 :D。

*

附言真的不知道它是否实际工作或“工作”。

*

new fiddle here 还改变了那个渐变背景,因为它让我头晕!

关于javascript - 使用鼠标位置在网页上滚动 - 将鼠标悬停在侧面元素上,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25423336/

相关文章:

html - 使用 em 代替 px 时的最佳实践

javascript - 后台因架构错误而无法启动

javascript - 如何使用 Enzyme 浅包装器对作为 prop 传递给子组件的 React 函数进行单元测试

javascript - parse.com 将其绑定(bind)到成功 block

jQuery 插件 imagemapster 没有做任何事情

javascript - 如何为除具有特定类的所有元素添加事件?

javascript - 使用 javascript 添加表单字段..但在下面,而不是在侧面?

javascript - 调用数组的映射函数时丢失 this

asp.net-mvc - 通过 JQuery 将多个参数从 View 传递到 Controller 的最佳方法

html - QT html和CSS转pdf文件