有人看过用香草javascript制作的这种水平滚动/滑动效果吗?

时间:2013-05-30 04:36:31

标签: javascript

这里描绘了一个漂亮的水平滚动/滑动效果:http://www.queness.com/resources/html/scroll/horizontal.html。但我比jQuery更喜欢vanilla javascript。有没有人遇到类似香草味的东西?我在SO上找到的例子都是jQuery。如果我没有使用正确的搜索字符串,我很乐意了解我应该使用哪个字符串。

1 个答案:

答案 0 :(得分:3)

嗯,这不是我最漂亮的工作;但它会做到这一点。 HTML:

<!DOCTYPE html>
<html lang="en" dir="ltr">
    <head>
        <title>Scroll Horizontally</title>
        <meta charset="UTF-8" />
        <link rel="stylesheet" type="text/css" media="screen" href="scroll.css" />
        <script type="text/javascript" src="scroll.js"></script>
    </head>
    <body>
        <div id="wrapper">
            <div id="mask">
                <div id="item1" class="item">
                    <a name="item1"></a>
                    <div class="content">item1
                        <a href="#item1" class="panel">1</a> |
                        <a href="#item2" class="panel">2</a> |
                        <a href="#item3" class="panel">3</a> |
                        <a href="#item4" class="panel">4</a> |
                        <a href="#item5" class="panel">5</a>
                    </div>
                </div>
                <div id="item2" class="item">
                    <a name="item2"></a>
                    <div class="content">
                        item2 <a href="#item1" class="panel">back</a>
                    </div>
                </div>
                <div id="item3" class="item">
                    <a name="item3"></a>
                    <div class="content">
                        item3 <a href="#item1" class="panel">back</a>
                    </div>
                </div>
                <div id="item4" class="item">
                    <a name="item4"></a>
                    <div class="content">
                        item4 <a href="#item1" class="panel">back</a>
                    </div>
                </div>
                <div id="item5" class="item">
                    <a name="item5"></a>
                    <div class="content">
                        item5 <a href="#item1" class="panel">back</a>
                    </div>
                </div>
            </div>
        </div>
    </body>
</html>

scroll.css

@charset "UTF-8";
body {
    height:100%;
    width:100%;
    margin:0;
    padding:0;
    overflow:hidden;
}
#wrapper {
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
    background-color:#ccc;
    overflow:hidden;
}
#mask {
    width:500%;
    height:100%;
    background-color:#eee;
}
.item {
    width:20%;
    height:100%;
    float:left;
    background-color:#ddd;
}
.content {
    width:400px;
    height:300px;
    top:20%;
    margin:0 auto;
    background-color:#aaa;
    position:relative;
}
.selected {
    background:#fff;
    font-weight:700;
}
.clear {
    clear:both;
}

最后,有趣的部分。如果您有任何疑问,请告诉我。我的工作正常,但你永远不会知道。 scroll.js

(function(d, w){
    var modern = function(){
        return(d.addEventListener);
    }, event = function(elem, evt, fn){
        if(modern()) {
            elem.addEventListener(evt, fn, false);
        } else {
            elem.attachEvent("on" + evt, fn);
        }
    }, wh = function(elem, width, height){
        elem.style.width = width + "px";
        elem.style.height = height + "px";
    }, width = function(){
        return(parseInt(w.innerWidth || d.documentElement.clientWidth || d.getElementsByTagName("body")[0].clientWidth, 10));
    }, height = function(){
        return(parseInt(w.innerHeight|| d.documentElement.clientHeight|| d.getElementsByTagName("body")[0].clientHeight, 10));
    }, remove_class = function(elem, remove) {
        var new_name = "", classes = elem.className.split(" ");
        for(var i = 0, len = classes.length; i < len; i++) {
            if(classes[i] !== remove) {
                new_name += classes[i] + " ";
            }
        }
        elem.className = new_name;
    }, reSize = function(){
        var items = d.getElementsByClassName("item"), len = items.length, wid = width(), hei = height(), wrapper = d.getElementById("wrapper"), count;
        for(var i = 0; i < len; i++) {
            wh(items[i], wid, hei);
            if(items[i].getElementsByClassName("selected").length > 1) {
                count = i;
            }
        }
        wh(wrapper, wid, hei);
        wh(d.getElementById("mask"), parseInt(wid * len, 10), hei);
        scroll_to(wrapper, count, 0);
    }, scroll_to = function(elem, num, speed){
        if(speed > 0) {
            w.setTimeout(function(){
                elem.scrollLeft += ((num * width()) - elem.scrollLeft) / speed * 10;
                scroll_to(elem, num, speed - 5);
            }, 5);
        }
    }, init = function(){
        event(w, "resize", reSize);
        event(d, "click", function(e){
            var e = e || window.event, target = e.target || e.srcElement, panels = d.getElementsByClassName("panel"), parts = null;
            if(target.className.match(/panel/)) {
                for(var i = 0, len = panels.length; i < len; i++) {
                    remove_class(panels[i], "selected");
                }
                target.className += " selected";
                parts = target.href.split("");
                scroll_to(d.getElementById("wrapper"), parseInt(parts[parts.length-1], 10) - 1, 800);
                if(e.preventDefault) {
                    e.preventDefault();
                } else {
                    event.returnValue = false;
                }
                return(false);
            }
        });
    };
    // getElementsByClassName hack
    if(!d.getElementsByClassName) {
        d.getElementsByClassName = function(class_name){
            var elems = [], all = d.getElementsByTagName("*"), reg_ex = new RegExp("(^|\\s)" + class_name + "(\\s|$)");
            for(var i = 0, len = all.length; i < len; i++) {
                if(reg_ex.test(all[i].className)) {
                    elems.push(all[i]);
                }
            }
            return(elems);
        };
    }
    // Attach onload events
    if(modern()) {
        d.addEventListener("DOMContentLoaded", init, false);
    } else {
        d.attachEvent("onreadystatechange", function(){
            if(d.readyState === "complete") {
                init();
            }
        });
    }
})(document, window);

修改 经过一些调整,现在回到IE7。我不会测试6,对不起芽。