0

我尝试制作一个类似于 iPhone unlock Slider 的滑块,它在完成后转发到链接的站点,并在滑块未拖动到末尾时返回其初始位置。

这并不意味着是一个 iPhone webapp,我只是想把它放到一个通用网站上作为效果。

到目前为止,我已经尝试了这两个测试,但我都坚持了下来。

第一个是:

// First Example
var el = $('slideOne'),

// Create the new slider instance
var sliderOne = new Slider(el, el.getElement('.slider'), {
    steps: 20,  // There are 35 steps
    range: [8], // Minimum value is 8

}).set(20);

这里的问题是我不能在(0)而不是(20)上触发事件,我尝试了 onComplete 但这会在页面加载后立即触发该功能!?

第二

$$('.textslider').setStyle('opacity', 0.8);

    $('slider1').makeDraggable({
        snap: 0,
        container: 'slideOne',
        droppables: '.slidedrop1',

    onDrop: function(element, droppable, event){
        if (!droppable);
        else console.log(element, 'dropped on', droppable, location = 'index.php/kredite.html', event);
    },
});

这里的问题是,droppable 不能像我希望的那样工作,有时我将滑块移动到不可见的 droppable 上,这表明滑块是否被拖到最后,并且没有任何反应,有时它工作正常,我想这可能是由于滑块上光标的位置不同。而且我无法完成它只能水平滑动,因为它是拖动而不是滑块功能,所以我认为这将是正确的方法。

在这两个测试中,我没有想出我可以用幻灯片效果将滑块返回到其初始位置的人。

周围是否有一些 mootools 裂缝可以帮助我解决这个问题?已经感谢你们的好主意。

4

1 回答 1

0
<html>
<head>
    <script type="text/javascript"
      src="http://demos.mootools.net/demos/mootools.js"></script>
    <script type="text/javascript">
    window.addEvent('domready', function(){
        var el = $('slideOne');
        var debug = $('debug');
        var ACTIVATE_VALUE = 20;
        var mySlider = new Slider(el, el.getElement('.knob'), {
            range: [0], // Minimum value
            steps: ACTIVATE_VALUE,  // Number of steps
            onChange: function(value){
                if (value == ACTIVATE_VALUE) {
                    debug.setStyles({color:'green'});
                    // go to url after delay
                    (function(){
                        location.href='http://joecrawford.com/';
                    }).delay(500);
                } else {
                    debug.setStyles({color:'red'});
                    // if not activated, reset after 2 second delay
                    (function(){
                        value = 0;
                        mySlider.set(value);
                    }).delay(3000);
                }
                debug.set('text', value);
            }
        });
        mySlider.set(0);
    }); 
    </script>
    <style type="text/css">
    div.slider {
        width: 200px;
        height: 50px;
        background: #eee;
    }
    div.slider div.knob {
        background: #000;
        width: 50px;
        height: 50px;
    }
    div#debug {
        font-family: sans-serif;
        font-size: xx-large;
    }
    </style>
    <title>Slider that resets if it does not reach the end</title>
</head>
<body>
    <div id="slideOne" class="slider">
        <div class="knob"></div>
    </div>
    <div id="debug">-</div>
</body>
</html>
于 2009-11-08T18:42:33.407 回答