Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Определить нажатую кнопку мыши. (https://javascript.ru/forum/misc/56-opredelit-nazhatuyu-knopku-myshi.html)

Phoenix 30.09.2007 13:42

Определить нажатую кнопку мыши.
 
Привет всем. Вопрос ужасно банален и смешон. Но я перерыл пол интернета, не нашел нормальный ответ на него...

Для определения нажатия кнопки есть событие event.button. Но на сей раз выделились Опера и ФФ, они его полностью игнорируют...

Как можно сделать кросбраузерную проверку на события мыши? Мне нужно реализовать перетаскивание слоя, при зажатой левой кнопке.

Илья Кантор 30.09.2007 21:33

Да просто по-разному устроены события там.

if (event.which == null)
       /* IE case */
       button= (event.button < 2) ? "LEFT" :
                 ((event.button == 4) ? "MIDDLE" : "RIGHT");
    else
       /* All others */
       button= (event.which < 2) ? "LEFT" :
                 ((event.which == 2) ? "MIDDLE" : "RIGHT");

Phoenix 30.09.2007 22:38

Я это читал... всеравно не верно! в IE все просто, там значение 1 принемает левая кнопка, в опере не могу найти такое значение. В ФФ вообще не могу найти значение... (event is not defined).

При onClick конечно все работает! но мне надо это определять на onMouseMove... А вот с ним уже замарочки начинаются :(

Илья Кантор 01.10.2007 00:14

Какая нафиг кнопка на mousemove ? Это же перемещение, а не нажатие.

Phoenix 01.10.2007 10:04

Ну да, но мне надо определить какая в этот момент нажата кнопка, можно иначе, на onMouseDown передать глобальной переменно значение 1 допустим. А при перемещении(onmousemove) проверять значение, если 1, то перетаскивать, если 0, то игнорировать. На onMouseUp поставить этой переменной 0.

Но имхо, это не оптимальный выход. :)

Phoenix 01.10.2007 10:43

И еще...

/* All others */
       button= (event.which < 2) ? "LEFT" :
                 ((event.which == 2) ? "MIDDLE" : "RIGHT");


В ФФ всеравно не работает, никакого ответа нет :(

Илья Кантор 01.10.2007 14:48

Код проверен на событиях клика мышой всеми кнопами.

Phoenix 01.10.2007 17:43

Цитата:

Сообщение от Илья Кантор (Сообщение 229)
Код проверен на событиях клика мышой всеми кнопами.

Ну не знаю...

попробуй такой код в ФФ:
<script>
function but(){
if (event.which == null)
       /* IE case */
       button= (event.button < 2) ? "LEFT" :
                 ((event.button == 4) ? "MIDDLE" : "RIGHT");
    else
       /* All others */
       button= (event.which < 2) ? "LEFT" :
                 ((event.which == 2) ? "MIDDLE" : "RIGHT");
alert(button);
//    return button;
}
</script>
<input type="button" onCLick="but()" value="Нажми"/>


У меня ФФ дебагер выдает такую ошибку:

event is not defined
if (event.which == null)

Илья Кантор 01.10.2007 17:55

Ну конечно, тебе ж нужен объект event еще.

Phoenix 01.10.2007 18:40

А как его реализовать? если правильно понял, то он равносилен document.event?

Илья Кантор 01.10.2007 21:10

Попробуй объявить function but(event){

Phoenix 02.10.2007 00:18

вообще перестала работать....

function pres_but(event){
if (event.which == null)
/* IE case */
button= (event.button < 2) ? "LEFT" :
((event.button == 4) ? "MIDDLE" : "RIGHT");
else
/* All others */
button= (event.which < 2) ? "LEFT" :
((event.which == 2) ? "MIDDLE" : "RIGHT");
return button;
}

//оба не работают(
pres_but();
pres_but(document.event);

Покажи пожалуйста правильный код работы, что то вообще понять не могу :(

Илья Кантор 02.10.2007 01:45

А как ты подключаешь обработчик к элементу?

Phoenix 02.10.2007 11:13

Вот мой код...

function pres_but(){
if (event.which == null)
button= (event.button < 2) ? "LEFT" :
((event.button == 4) ? "MIDDLE" : "RIGHT");
else
button= (event.which < 2) ? "LEFT" :
((event.which == 2) ? "MIDDLE" : "RIGHT");
return button;
}

function what_but(){
if (pres_but()=="LEFT") {drag_pan=1;}
}

<td height='24' class='close_pan' onMouseMove='move_pan()' onMouseDown='what_but()' onMouseUp='def_pan()'>

//с function pres_but(event) вообще не работает(я неверно похоже объявляю).
p.s. Мой код работает в Опере и ИЕ. В ФФ не хочет(

Phoenix 02.10.2007 11:57

Пока делеал перетаскивание, возникла еще одна проблема. При перетаскивании, текст который находится под курсором выделяется. Как можно это выделение отменить(запретить), что бы более красиво смотрелось перетаскивание.

Илья Кантор 02.10.2007 12:24

onMouseMove='move_pan()' onMouseDown='what_but()' onMouseUp='def_pan()'>


вот это замени на

onMouseMove='move_pan(event)' onMouseDown='what_but(event)' onMouseUp='def_pan(event)'>


и вот это

function what_but(event){
   if (pres_but(event)=="LEFT") {drag_pan=1;}
}

Phoenix 02.10.2007 18:46

Спасибо большое, разобрался! У меня еще в коде были ошибки с Event, изменил, теперь работает все отлично!

Phoenix 02.10.2007 22:37

Возникла еще одна проблемка в Опере. Когда идет обработка события onMouseMove(я его на body повесил, что бы более правильнее работало перемещение). В Опере выделяется текст под курсором, в ИЕ и ФФ этого нет. Как можно заблокировать выделение или сбросить? а то некрасиво смотрится :(

Илья Кантор 03.10.2007 18:57

Вот функция, тока она похоже в Опере не пашет. Я сам оперой не занимаюсь =(
setSelectable = function(/*Node|String*/node, /*Boolean*/selectable){
                // summary: enable or disable selection on a node
                node = dojo.byId(node);
                if(dojo.isMozilla){
                        node.style.MozUserSelect = (selectable) ? "" : "none";
                }else if(dojo.isKhtml){
                        node.style.KhtmlUserSelect = (selectable) ? "auto" : "none";
                }else if(dojo.isIE){
                        node.unselectable = (selectable) ? "" : "on";
                        dojo.query("*", node).forEach(function(descendant){
                                descendant.unselectable = (selectable) ? "" : "on";
                        });
                }
                //FIXME: else?  Opera?
        };


Часовой пояс GMT +3, время: 00:49.