国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Javascript實現的簡單右鍵菜單類

2019-11-20 11:31:57
字體:
來源:轉載
供稿:網友

本文實例講述了Javascript實現的簡單右鍵菜單類。分享給大家供大家參考。具體如下:

這是自己寫的一個右鍵菜單類,屏蔽掉了IE固有的右鍵菜單,一共有四個參數:第一個是出發顯示右鍵菜單的div的id

第二個是右鍵菜單這個層的id,根據這個id去創建一個新的層,menuList是菜單項的列表,對應了點擊一個菜單項后觸發的函數,classList是菜單的class名稱,以及菜單項對應的class名稱,包含了鼠標滑過時的class。

運行效果截圖如下:

在線演示地址如下:

http://demo.VeVB.COm/js/2015/js-right-button-menu-class-codes/

具體代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=gb2312" /><title>右鍵菜單</title><style type="text/css">.cmenu{ position:absolute; top:100px; left:100px; width:200px; height:200px; background-color:white; border:1px solid pink;}.liAble{ font-family:"宋體"; color:#6699CC; margin-left:10px; margin-top:5px; list-style-type:none; cursor:default;}.liMouseOver{ margin-left:10px; margin-top:5px; background-color:#CCFFFF; list-style-type:none; cursor:default;}</style></head><body><div style="margin-left:auto; margin-right:auto; height:300px; width:60%;background-color:#CC6699" id="x"></div><input type="hidden" id="value1" value="4" /><input type="hidden" id="value2" value="5" /><script type="text/javascript">//右鍵菜單類function RightHandMenu(div,menuDiv,menuList,classList){ var oThis = this; this._menuList =  { } this._classList =  {  objClass:'',  MenuClass:'',  liAbleClass:'',  liMouseOverClass:'' } this.Init = function() {  this._obj = $(div);  this._obj.oncontextmenu = function(e){oThis.ShowMenu(e)};  this._obj.className = this._classList.objClass;  document.onclick = function(){oThis.HiddenMenu()};  objToObj(this._classList, classList);  objToObj(this._menuList, menuList); } this.CreateMenu = function() {  if($(menuDiv))  {   alert("該ID已被占用");   return;  }  this._menu = document.createElement("DIV");  this._menu.id = menuDiv;  this._menu.oncontextmenu = function(e){stopBubble(e)};  this._menu.className = this._classList.MenuClass;  this._menu.style.display = "none";  document.body.appendChild(this._menu); } this.CreateMenuList = function() {  for(var pro in this._menuList)  {   var li = document.createElement("LI");   li.innerHTML = pro;   this._menu.appendChild(li);   li.className = this._classList.liAbleClass;   li.onclick = this._menuList[pro];   li.onmouseover = function(){oThis.ChangeLiClass(this,oThis._classList.liMouseOverClass)}   li.onmouseout = function(){oThis.ChangeLiClass(this,oThis._classList.liAbleClass)}  } } this.ChangeLiClass = function(obj,name) {  obj.className = name } this.ShowMenu = function(e) {  var e = e || window.event;  stopBubble(e);  var offsetX = e.clientX;  var offsetY = e.clientY;  with(this._menu.style)  {   display = "block";   top = offsetY + "px";   left = offsetX + "px";  } } this.HiddenMenu = function() {  this._menu.style.display = "none"; } this.Init(); this.CreateMenu(); this.CreateMenuList();}function stopBubble(oEvent){ if(oEvent.stopPropagation) oEvent.stopPropagation(); else oEvent.cancelBubble = true;  if(oEvent.preventDefault) oEvent.preventDefault(); else oEvent.returnValue = false;}function $(div){ return 'string' == typeof div ? document.getElementById(div) : div;}function objToObj(destination,source){ for(var pro in source) {  destination[pro] = source[pro]; } return destination;}//構造右鍵菜單function Edit(){ alert("edit");}function Delete(){ alert("delete");}var menuList = { 編輯:Edit, 刪除:Delete}var classList = { MenuClass:'cmenu', liAbleClass:'liAble', liMouseOverClass:'liMouseOver'}var x = new RightHandMenu("x","testDiv",menuList,classList)</script></body></html>

希望本文所述對大家的JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 垣曲县| 会宁县| 思南县| 简阳市| 吴旗县| 屏山县| 连江县| 牡丹江市| 太湖县| 景宁| 额尔古纳市| 晋州市| 中超| 扬中市| 巴林左旗| 轮台县| 东海县| 吉隆县| 洞头县| 定结县| 博湖县| 贵南县| 洛扎县| 大方县| 监利县| 江山市| 九江市| 吉木萨尔县| 徐水县| 九寨沟县| 卢龙县| 林州市| 广灵县| 荣成市| 大城县| 湖口县| 瓦房店市| 通榆县| 蒙城县| 星座| 怀化市|