Контекстное меню в браузере средствами HTML5. Обработка нажатия правой кнопки мыши (oncontextmenu) Что есть контекстное меню

З амечали ли вы, что щелчки правой кнопкой мыши по картинкам на некоторых сайтах ни к чему не приводят. Кажется, будто кнопка щелкает вхолостую, а браузеру нет до неё никакого дела – «завис и думает». В действительности же браузер просто блокирует клики, получив такую команду из JavaScript-сценария загруженной страницы.

Как же разблокировать правую кнопку , чтобы кликнув по картинке, сохранить её для просмотра в офф-лайне? В большинстве интернет-обозревателей для этого достаточно «покопаться» в расширенных настройках JavaScript .. Итак…

Если у Вас «Opera »:
1. Проследуйте по пути «Инструменты» -> «Общие настройки»;
2. В появившемся окошке остановитесь на пункте «Содержимое» и отыщите кнопку «Настроить JavaScript» (см.рис.1).

3. Кликнув по ней, вызовите окошко детальных настроек JavaScript и уберите галочку напротив строки «Блокировать правую кнопку».
После подтверждения (нажатия на «Ok») эта кнопка станет «свободной» для вызовов контекстного меню. Кстати в «FireFox » для разблокировки правой кнопки нужно снять галочку именно возле такого пункта (см. рис.2).

В других же продвинутых браузерах блокировка правой кнопки снимается аналогично – через те же расширенные настройки JavaScript.

Задача: отловить нажатие правой кнопки мыши в окне браузера и показать собственное контекстное меню.

Что происходит при нажатии правой кнопки мыши в окне браузера? Появится контекстное меню, внешний вид и набор функций которого будет зависеть от типа браузера и того места, куда вы кликнули.
А что, если мы захотели заблокировать браузерное контекстное меню и показать собственное? Возможно? Да. К сожалению не кроссбраузерно, но код приведенный ниже будет работать в Gecko, Safari и IE. Opera таких возможностей по умолчанию не предоставляет.

Для начала прорисуем три DIV-а, в 2-х из которых покажем собственное контекстное меню, а в третьем оставим дефолтное браузерное.

"height:100px; border:1px solid red; background-color:#FFCCCC;" > Кликни правой кнопкой

"height:100px; border:1px solid blue; background-color:#CCCCFF;" > Кликни правой кнопкой

"height:100px; border:1px solid green; background-color:#CCFFCC;" > Кликни правой кнопкой


"position:absolute; top:0; left:0; border:1px solid #666; background-color:#CCC; display:none; float:left;" >


Как видите, отлов нажатия правой кнопки происходит с помощью события oncontextmenu . Для написания кода функции menu необходимы следующие составляющие:
– Функция для добавления обработчиков событий . Используется для скрытия собственного контекстного меню при кликах в других частях документа.
– Функция для определения координат указателя мыши . Используется для определения положения, в котором мы покажем контекстное меню.
Блокировать всплывание стандартного браузерного меню можно элементарно возвращая false.

Теперь код:

// Функция для определения координат указателя мыши
function defPosition(event) {
var x = y = 0 ;
if (document.attachEvent != null ) { // Internet Explorer & Opera
x = window.event .clientX + (document.documentElement .scrollLeft ? document.documentElement .scrollLeft : document.body .scrollLeft ) ;
y = window.event .clientY + (document.documentElement .scrollTop ? document.documentElement .scrollTop : document.body .scrollTop ) ;
} else if (!document.attachEvent && document.addEventListener ) { // Gecko
x = event.clientX + window.scrollX ;
y = event.clientY + window.scrollY ;
} else {
// Do nothing
}
return { x:x, y:y} ;
}

function menu(type, evt) {
// Блокируем всплывание события contextmenu
evt = evt || window.event ;
evt.cancelBubble = true ;
// Показываем собственное контекстное меню
var menu = document.getElementById ("contextMenuId" ) ;
var html = "" ;
switch (type) {
case (1 ) :
html = "Меню для первого ДИВа" ;
html += "
Первая функция"
;
html += "
Вторая функция"
;
html += "
Третья функция"
;
break ;
case (2 ) :
html = "Меню для второго ДИВа" ;
html += "
(пусто)" ;
break ;
default :
// Nothing
break ;
}
// Если есть что показать - показываем
if (html) {
menu.innerHTML = html;
menu.style .top = defPosition(evt) .y + "px" ;
menu.style .left = defPosition(evt) .x + "px" ;
menu.style .display = "" ;
}
// Блокируем всплывание стандартного браузерного меню
return false ;
}

// Закрываем контекстное при клике левой или правой кнопкой по документу
// Функция для добавления обработчиков событий
function addHandler(object, event, handler, useCapture) {
if (object.addEventListener ) {
object.addEventListener (event, handler, useCapture ? useCapture: false ) ;
} else if (object.attachEvent ) {
object.attachEvent ("on" + event, handler) ;
} else alert ("Add handler is not supported" ) ;
}
addHandler(document, "contextmenu" , function () {

} ) ;
addHandler(document, "click" , function () {
document.getElementById ("contextMenuId" ) .style .display = "none" ;
} ) ;

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

Вначале следует выяснить, почему происходит сбой в работе, почему не работает контекстное меню Windows 10. Здесь возможны несколько причин:

  • захламлённость реестра устаревшими файлами;
  • отсутствие программ, включённых в контекстное меню, их нестабильная работа.

Рассмотрим, что делать в этих случаях, как изменить ситуацию, когда не открывается контекстное меню правой кнопкой мыши.

Если не появляется контекстное меню по правой кнопке из-за захламлённости реестра устаревшими файлами, рекомендуем для очистки воспользоваться утилитой, например, Glary Utilities. Glary Utilities представляет собой комплект системных твикеров, утилит, способствующих защите, тонкой настройке, повышению производительности ПК. С помощью набора можно удалить ненужные файлы , засоряющие систему, записи в реестре, давно устаревшие, оптимизировать оперативку, управлять автозагрузкой, оптимизировать память и иные функции, полезные для хорошего функционирования компьютера. Glary Utilities можно скачать бесплатно.


Проставив настройки, очистите ваше устройство от ненужных файлов посредством этой же утилиты, почистите реестр , тем самым увеличив быстродействие компьютера.

Исправление ошибки зависания

Если при нажатии ПКМ на файл, папку, не работает контекстное меню на рабочем столе, компьютер зависает, клавиша не реагирует на команды, можно устранить это зависание двумя способами, советуем выполнить оба последовательно. Прежде чем приступать к любому из них, нужно иметь права администратора . Вам придётся работать с реестром, здесь надо быть осторожным, при неправильных действиях система может отказать. Поэтому, приступая к процессу исправления сбоев, создайте непременно точку восстановления системы, прежде чем что-либо удалите.

«Глухое» зависание вызывается, как правило, нестабильно работающей программой, зависшей программой либо когда ссылка в контекстном меню, указывает на ресурс несуществующий.

Способ первый

Выполняйте последовательно шаги:



  1. Проверьте появившейся список на наличие удалённых уже вами программ.
  2. Если есть в списке программа, которую вы удаляли, уберите её из реестра. Перед удалением любого раздела реестра рекомендуем создавать его архивную копию для сохранения на случай необходимости восстановить.

Способ второй

Алгоритм при втором способе, когда у вас не открывается контекстное меню Windows 10, будет следующим.

  1. Откройте редактор реестра, как описывалось в пунктах 1–2 предыдущего способа.
  2. Откройте подраздел HKEY_CLASSES_ROOT,
  3. В нем увидите несколько подразделов с названиями, как «name_programm.exe», «name_programm.dll». Поочерёдно проверьте каждый, кликая ЛКМ, до подраздела «command». Все подразделы должны открываться. Если не открывается, в правой части окна смотрите наличие параметра «NoOpenWith». Нет такого параметра - создайте его. Для чего выполните действия:

  1. Найдя подраздел «command», кликните ЛКМ, проверьте наличие в правой части параметра «(По умолчанию)». В параметре должен быть прописан на приложение либо сетевой ресурс, существующие в компьютере.
  • Если параметр ссылается на отсутствующий уже ресурс, удалить следует весь раздел, начинающийся с названия этого ресурса, программы. Не забудьте перед удалением создать архивную копию для восстановления при необходимости. Удаляете, кликнув по названию раздела ПКМ, затем нажав «Удалить» - «Да».

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

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

Похожие публикации