zoukankan      html  css  js  c++  java
  • javascript右键菜单分析

    右键菜单

    思路

    1、遮蔽原来的默认右键菜单

    2、新建右键菜单跟随鼠标移动

    3、注意边界处的位置变化

    4、自定义右键内容的具体效果

    具体

    这样的事件涉及到有关contextmenu事件,阻止默认事件,获取鼠标点击位置,涉及到offsetWidth等等,具体展示

    offsetWidth:元素在水平方向占据的空间,只包括width padding border

    offsetHeight:元素在垂直方向占据的空间,只包括height padding border

    offsetTop:偏移量,相对于已定位元素的后代元素,返回的是相对于祖先元素,否则返回相对文档元素,返回的是top距离

    offsetLeft:偏移量,相对于已定位元素的后代元素,返回的是相对于祖先元素,否则返回相对文档元素,返回的是left距离

    clientX:可视区的坐标,为横坐标;当然也是event.clientX

    clientY:可视区的坐标,为纵坐标,同理event.clientY

    clientWidth:只包含width padding 

    clientHeight:只包含height padding

    对于获取整个的页面的可以 document.documentElement.clientWidth||document.body.clientWidth ,不包含滚动条

    scrollTop:滚动的距离,包含边框

    scrollLeft::滚动的距离,包含边框

    对于获取scrollTop可以 document.documentElement.scrollTop||document.body.scrollTop 

    scrollWidth:没有滚动条下,页面的总宽度

    scrollHeight:没有滚动条下,页面的总高度,对于这两个属性,不同浏览器有所差异,必须兼容性,js高程上有的。

    pageX/Y:整个页面的坐标,不是clientX/Y可视区的坐标

    screenX/Y:参照点是整个屏幕的左上角,不限于浏览器

             //右键菜单重置
             document.oncontextmenu=function(event){
                     var event=event||window.event
                     event.preventDefault()  //阻止默认事件
                     event.returnValue=false
    var clientWidth=document.documentElement.clientWidth var clientHeight=document.documentElement.clientHeight move.style.display='block' //基于当前可视区的 if(clientHeight-event.pageY>=move.offsetHeight){ move.style.top=event.pageY+'px' }else{ move.style.top=(event.pageY-move.offsetHeight)+'px' } if(clientWidth-event.pageX>=move.offsetWidth){ move.style.left=event.pageX+'px' }else{ move.style.left=(event.pageX-move.offsetWidth)+'px' } }

     这是主要的代码,阻止默认事件,限定所要展示的菜单的位置

    当然,对于里面所要跳转的页面,只需添加即可,比如:

               <li><a href="javascript:history.go(1)">返回</a></li>
               <li><a href="javascript:history.go(-1)">前进</a></li>
               <li><a href="javascript:location.reload()">重新加载</a></li>

    返回和前进,重新加载,用到BOM的相关知识。

  • 相关阅读:
    geotrellis使用(二十八)栅格数据色彩渲染(多波段真彩色)
    我的2016,感恩、乐观、努力
    我的奋斗——从印刷工人到地理信息大数据系统程序员
    geotrellis使用(二十七)栅格数据色彩渲染
    用户画像
    栈和队列在python中的实现
    跳一跳第一天总结
    在pycharm中使用scrapy爬虫
    用户使用手册
    项目测试报告和用户使用手册
  • 原文地址:https://www.cnblogs.com/iDouble/p/8540384.html
Copyright © 2011-2022 走看看