Jquery Diagonal Scrolling Div

时间:2012-11-16 17:54:30

标签: javascript jquery html scroll

如果你看一下这个插件:http://cubiq.org/infiniwall

您可以向任何方向滚动div容器,而不仅仅是水平或垂直方向,也可以在滚动期间更改方向而无需移开手指。

我怎样才能做到这一点?我似乎找不到允许它的插件。

提前致谢。

1 个答案:

答案 0 :(得分:0)

我相信您需要<div id="infiniwall"> var iw = new InfiniWall('#infiniwall');并注意使用<!DOCTYPE html>

https://github.com/cubiq/infiniwall/tree/master/demos/simple

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>InfiniWall - Indefinitely panning layer in Javascript</title>
    <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=0, minimum-scale=1.0, maximum-scale=1.0">
    <script src="../../src/infiniwall.js"></script>
</head>

<style>
* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

body, ul, li {
    padding: 0;
    margin: 0;
    border: 0;
}

#infiniwall {
    margin: 140px auto 0 auto;
    width: 510px;
    height: 420px;
    background: #ddd;
    overflow: hidden;
    position: relative;
}

ul {
    position: absolute;
    top: -140px;
    left: -170px;
    width: 850px;
    height: 700px;
    list-style: none;

    -webkit-transform: translate(0px, 0px) translateZ(0);
    -moz-transform: translate(0px, 0px) translateZ(0);
    -ms-transform: translate(0px, 0px) translateZ(0);
    -o-transform: translate(0px, 0px) translateZ(0);
    transform: translate(0px, 0px) translateZ(0);
}

li {
    display: block;
    position: relative;
    float: left;
    width: 170px;
    height: 140px;
    -webkit-transform: translate(0px, 0px) translateZ(0);
    -moz-transform: translate(0px, 0px) translateZ(0);
    -ms-transform: translate(0px, 0px) translateZ(0);
    -o-transform: translate(0px, 0px) translateZ(0);
    transform: translate(0px, 0px) translateZ(0);
    display: block;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
    overflow: hidden;
}

li img {
    position: absolute;
}

.spinner {
    display: block;
    position: absolute;
    width: 40px;
    height: 40px;
    left: -9999px;
    top: 50%;
    margin-top: -35px;
    margin-left: -20px;
    background: url(images/loading.png) no-repeat;
}

.loading .spinner {
    left: 50%;
    -webkit-animation: spin 2s linear infinite;
    -moz-animation: spin 2s linear infinite;
    -o-animation: spin 2s linear infinite;
    animation: spin 2s linear infinite;
}

@keyframes spin {
    from {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    to {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@-moz-keyframes spin {
    from {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    to {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@-webkit-keyframes spin {
    from {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    to {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@-o-keyframes spin {
    from {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    to {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

.loading img {
    left: -9999px;
}

li span {
    position: absolute;
    bottom: 0;
    width: 100%;
    background: rgba(0,0,0,0.6);
    color: #fff;
    padding: 5px;
    font-size: 19px;
}

</style>
<body>
    <div id="infiniwall">
        <ul>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>

            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>

            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>

            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>

            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
        </ul>
    </div>

<script>
document.addEventListener('touchmove', function (e) { e.preventDefault(); }, false);
var iw = new InfiniWall('#infiniwall');
</script>

</body>