ホームページ >ウェブフロントエンド >jsチュートリアル >右クリックメニューのカスタマイズ

右クリックメニューのカスタマイズ

高洛峰
高洛峰オリジナル
2016-10-29 10:26:111476ブラウズ

カスタマイズされた右クリック メニュー

一部の ERP システムでは、多くの機能操作があるため、通常、ユーザーの利便性を考慮して、よく使用されるいくつかの機能がカスタマイズされた右クリック メニューに組み込まれています。

カスタム メニューの実装は非常に簡単です。まず、元の右クリック メニューをブロックして、カスタム メニューを非表示にします。

*{margin:0;padding:0}
a{text-decoration:none}
ul li{list-style:none}
.menu{border:1px solid black;border-radius:5px;display:inline-block;position:fixed;top:100px;left:550px;
overflow:hidden;padding-bottom:10px;box-shadow:0 0 10px 0;z-index:999;display:none;background:white}
.menu ul li{height:30px;width:100%}
.menu ul li a{height:30px;display:inline-block;width:100%;text-align:left;line-height:30px;padding:5px 10px}
.menu li a:hover{background-color:#EEF5E2}
<div class="menu" id="demo">
    <ul>
        <li><a href="#">向录入员发送消息</a></li>
        <li><a href="#">发送选中作业</a></li>
        <li><a href="#">设置作业状态</a></li>
        <li><a href="#">哈哈哈哈哈</a></li>
        <li><a href="#">嘻嘻嘻嘻嘻</a></li>
        <li><a href="#">呵呵呵呵呵呵</a></li>
    </ul>
  </div>

1.元の右クリックメニューをシールドする

これを実現するためにJSで提供されているイベントがあり、これはイベントバインドされた領域です。右クリックすると、元の右クリックメニューが表示されます。表示されなくなりました:

document.oncontextmenu = function(){  return false;
}

2. カスタム メニューのサイズを取得します

カスタム メニューは最初は非表示になっており、非表示の要素の幅と高さを取得する方法がありません。まずメニュー要素を可視性: 非表示に設定し、要素の幅と高さを取得してから、この属性を削除します:

function getHideDOMWH(obj){
      //obj为菜单元素的DOM对象
      var wh = {};
      obj.style.visibility = "hidden";
      wh.w = obj.scrollWidth;
      wh.h = obj.scrollHeight;
      obj.style.visibility = null;
      return wh;
  }

3. カスタム メニューが現在のマウス位置に表示されます

まず、現在のマウスの位置を取得する必要があります。マウスの位置 、現在のマウスの位置はカスタム メニューが表示される場所です。同時に、右からの距離や下からの距離がメニューを表示するのに十分でない状況にも注意してください:

document.onmousedown = function(e){
    //obj为菜单元素DOM对象
    var e = e || window.event;
    if(e.button==2){
        var left = e.clientX;
        var top = e.clientY;
        var windowHeight = document.body.scrollHeight;
        var windowWidth = document.body.scrollWidth;
        var wh = getHideDOMWH(obj);
        var contentHeight = wh.h;
        var contentWidth = wh.w;
        obj.style.left = windowWidth-left>contentWidth?left+"px":windowWidth-contentWidth+"px";
        obj.style.top = windowHeight-top>contentHeight?top+"px":top-contentHeight+"px";
        obj.style.display = "inline-block";
    }
}

ブラウザウィンドウの幅からカーソルがクリックされたときの左からの距離を引いたときはメニューの幅より小さいので、カーソルから右への距離を意味します。これではメニューを表示するだけでは不十分なので、このときメニューの左の値は右に固定されます。ブラウザウィンドウの幅からメニューの幅を引いた値。ブラウザウィンドウの高さからカーソルから上辺までの距離を引いた値がメニューの高さより小さい場合、このときカーソルから下辺までの距離がメニューを表示するには十分ではないことを意味します。メニューの上部の値は、カーソルから上部までの距離からメニューの高さの距離を引いたものです。

4. メニュー要素をクリックしても、他の要素をクリックしても、メニューを非表示にします

document.onclick = function(){    //obj为菜单元素DOM对象
    obj.style.display = "none";
}

使いやすくするために、上記のプロセスをメソッドにカプセル化するか、ネイティブ JS 要素 (IE7 と以下はエラーを報告します)、または JQ のプロトタイプでは、メソッドをカプセル化します。

function contextMenu(obj){
      //obj为DOM对象
      document.oncontextmenu = function(){
          return false;
      }
      document.onmousedown = function(e){
          var e = e||window.event;
          if(e.button==2){
              var mouseX = e.clientX;
              var mouseY = e.clientY;
              var wh = getObjWH(obj);
              var contentW = wh.w;
              var contentH = wh.h;
              var documentW = document.body.scrollWidth;
              var documentH = document.body.scrollHeight;
              obj.style.left = documentW-mouseX<contentW?documentW-contentW+"px":mouseX+"px";
              obj.style.top = documentH-mouseY<contentH?mouseY-contentH+"px":mouseY+"px";
              obj.style.display = "inline-block";
          }
          
      }
      document.onclick = function(){
          obj.style.display = "none";
      }
      function getObjWH(obj){
          var wh = {};
          obj.style.visibility = "hidden";
          wh.w = obj.scrollWidth;
          wh.h = obj.scrollHeight;
          obj.style.visibility = null;
          return wh;
      }
  }

すべてのイベントはドキュメントにバインドされており、通常、特定の要素にバブリングのキャンセルを設定すると、いくつかの問題が発生するため、対象を絞った対処を行う必要があります。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。