scripty (scriptaculous) перетаскиваемый onEnd не выполняется в Safari - PullRequest
0 голосов
/ 22 февраля 2009

Я создал очень простой элемент iphone-y slider, который ограничен в общем перемещении по горизонтали (0-400 пикселей и не перемещается по вертикали) и «привязывается» к любой стороне 400-пиксельного «контейнера», когда он прошел отметка 200px и перетаскивание закончилось. Он отлично работает в Firefox. В Safari никогда не вызывается функция onEnd, которая помещает элемент в любой конец этого 400-пиксельного контейнера. Более того, перетаскиваемый элемент «прилипает» к курсору мыши, и мне нужно перезагрузить страницу, чтобы завершить анимацию.

Вот мой код

<div style="width:100px;height: 60px;background-color:#000;z-index:999" id="dragtest" />
<script language="JavaScript" type="text/javascript">
new Draggable('dragtest', { constraint: 'horizontal',
    onEnd: function(e, me) {
        console.debug("!!!")
        element = e.element
        x = element.style.left
        x = x.gsub('px','')

        if (x >= 200) {
            $('dragtest').style.left = 400+'px';

        }

        if (x < 200) {
            $('dragtest').style.left = 0+'px';
        }

        console.debug("Snapping to ", element.style.left, " (x was ", x, ")")
        return true;

    },
    snap: function(x, y) {
        ret_x = x
        ret_y = y

        if (x >= 400) {
            ret_x = 400
        }

        if (x <= 0) {
            ret_x = 0
        }

        return [ret_x,ret_y]

    }
});
</script>

спасибо! андрей

1 Ответ

0 голосов
/ 23 февраля 2009

Для справки в будущем (не могу что-нибудь из этого гуглить), устранение комментариев в вызовах console.debug () из обработчика onEnd решило эту проблему. Weird.

...