Home > Web Front-end > JS Tutorial > JS implements Windows 7 style web page right-click menu effect code_javascript skills

JS implements Windows 7 style web page right-click menu effect code_javascript skills

WBOY
Release: 2016-05-16 15:39:45
Original
1678 people have browsed it

本文实例讲述了JS实现仿Windows7风格的网页右键菜单效果代码。分享给大家供大家参考。具体如下:

这是一款JS仿Windows7风格的网页右键菜单,可以多级展开的右键菜单,原生JS。可参考性强,学习JavaScript的朋友不可错过。本菜单用户体验极佳,兼容性良好,无jQuery。

运行效果截图如下:

在线演示地址如下:

http://demo.jb51.net/js/2015/js-win7-style-web-right-menu-codes/

具体代码如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

<!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>

<title>自定义多级右键菜单</title>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<style type="text/css">

html,body{height:100%;overflow:hidden;}

body,div,ul,li{margin:0;padding:0;}

body{font:12px/1.5 \5fae\8f6f\96c5\9ed1;}

ul{list-style-type:none;}

#rightMenu{position:absolute;top:-9999px;left:-9999px;}

#rightMenu ul{float:left;border:1px solid #979797;background:#f1f1f1 url(images/line.png) 24px 0 repeat-y;padding:2px;box-shadow:2px 2px 2px rgba(0,0,0,.6);}

#rightMenu ul li{float:left;clear:both;height:24px;cursor:pointer;line-height:24px;white-space:nowrap;padding:0 30px;}

#rightMenu ul li.sub{background-repeat:no-repeat;background-position:right 9px;background-image:url(images/arrow_win7.png);}

#rightMenu ul li.active{background-color:#f1f3f6;border-radius:3px;border:1px solid #aecff7;height:22px;line-height:22px;background-position:right -8px;padding:0 29px;}

#rightMenu ul ul{display:none;position:absolute;}

</style>

<script type="text/javascript">

var getOffset = {

 top: function (obj) {

  return obj.offsetTop + (obj.offsetParent &#63; arguments.callee(obj.offsetParent) : 0)

 },

 left: function (obj) {

  return obj.offsetLeft + (obj.offsetParent &#63; arguments.callee(obj.offsetParent) : 0)

 }

};

window.onload = function ()

{

 var oMenu = document.getElementById("rightMenu");

 var aUl = oMenu.getElementsByTagName("ul");

 var aLi = oMenu.getElementsByTagName("li");

 var showTimer = hideTimer = null;

 var i = 0;

 var maxWidth = maxHeight = 0;

 var aDoc = [document.documentElement.offsetWidth, document.documentElement.offsetHeight];

 oMenu.style.display = "none";

 for (i = 0; i < aLi.length; i++)

 {

  //为含有子菜单的li加上箭头

  aLi[i].getElementsByTagName("ul")[0] && (aLi[i].className = "sub");

  //鼠标移入

  aLi[i].onmouseover = function ()

  {

   var oThis = this;

   var oUl = oThis.getElementsByTagName("ul");

   //鼠标移入样式

   oThis.className += " active";  

   //显示子菜单

   if (oUl[0])

   {

    clearTimeout(hideTimer);   

    showTimer = setTimeout(function ()

    {

     for (i = 0; i < oThis.parentNode.children.length; i++)

     {

      oThis.parentNode.children[i].getElementsByTagName("ul")[0] &&

      (oThis.parentNode.children[i].getElementsByTagName("ul")[0].style.display = "none");

     }

     oUl[0].style.display = "block";

     oUl[0].style.top = oThis.offsetTop + "px";

     oUl[0].style.left = oThis.offsetWidth + "px";

     setWidth(oUl[0]);

     //最大显示范围    

     maxWidth = aDoc[0] - oUl[0].offsetWidth;

     maxHeight = aDoc[1] - oUl[0].offsetHeight;

     //防止溢出

     maxWidth < getOffset.left(oUl[0]) && (oUl[0].style.left = -oUl[0].clientWidth + "px");

     maxHeight < getOffset.top(oUl[0]) && (oUl[0].style.top = -oUl[0].clientHeight + oThis.offsetTop + oThis.clientHeight + "px")

    },300);

   }  

  };

  //鼠标移出

  aLi[i].onmouseout = function ()

  {

   var oThis = this;

   var oUl = oThis.getElementsByTagName("ul");

   //鼠标移出样式

   oThis.className = oThis.className.replace(/\s&#63;active/,"");

   clearTimeout(showTimer);

   hideTimer = setTimeout(function ()

   {

    for (i = 0; i < oThis.parentNode.children.length; i++)

    {

     oThis.parentNode.children[i].getElementsByTagName("ul")[0] &&

     (oThis.parentNode.children[i].getElementsByTagName("ul")[0].style.display = "none");

    }

   },300);

  };

 }

 //自定义右键菜单

 document.oncontextmenu = function (event)

 {

  var event = event || window.event;

  oMenu.style.display = "block";

  oMenu.style.top = event.clientY + "px";

  oMenu.style.left = event.clientX + "px";

  setWidth(aUl[0]);

  //最大显示范围

  maxWidth = aDoc[0] - oMenu.offsetWidth;

  maxHeight = aDoc[1] - oMenu.offsetHeight;

  //防止菜单溢出

  oMenu.offsetTop > maxHeight && (oMenu.style.top = maxHeight + "px");

  oMenu.offsetLeft > maxWidth && (oMenu.style.left = maxWidth + "px");

  return false;

 };

 //点击隐藏菜单

 document.onclick = function ()

 {

  oMenu.style.display = "none"

 };

 //取li中最大的宽度, 并赋给同级所有li

 function setWidth(obj)

 {

  maxWidth = 0;

  for (i = 0; i < obj.children.length; i++)

  {

   var oLi = obj.children[i];  

   var iWidth = oLi.clientWidth - parseInt(oLi.currentStyle &#63; oLi.currentStyle["paddingLeft"] : getComputedStyle(oLi,null)["paddingLeft"]) * 2

   if (iWidth > maxWidth) maxWidth = iWidth;

  }

  for (i = 0; i < obj.children.length; i++) obj.children[i].style.width = maxWidth + "px";

 }

};

</script>

</head>

<body>

<center>自定义右键菜单,请在页面点击右键查看效果。</center>

<div id="rightMenu">

 <ul>

 <li><strong>JavaScript 学习</strong></li>

 <li>

  第一课

  <ul>

  <li>响应用户操作</li>

  <li>事件驱动</li>

  <li>元素属性操作</li>

  </ul>

 </li>

 <li>

  第二课

  <ul>

  <li>改变网页背景颜色</li>

  <li>函数传参</li>

  <li>126邮箱全选效果</li>

  <li>循环及遍历操作</li>

  </ul>

 </li>

 <li>

  第三课

  <ul>

  <li>

   JavaScript组成

   <ul>

   <li>ECMAScript</li>

   <li>DOM</li>

   <li>BOM</li>

   <li>JavaScript兼容性来源</li>

   </ul>

  </li>

  <li>JavaScript出现的位置、优缺点</li>

  <li>变量、类型、变量作用域</li>

  <li>

   闭包

   <ul>

   <li>什么是闭包</li>

   <li>简单应用</li>

   <li>闭包缺点</li>

   </ul>

  </li>

  <li>运算符</li>

  <li>程序流程控制</li>

  <li>

   定时器的使用

   <ul>

   <li>setInterval</li>

   <li>setTimeout</li>

   </ul>

  </li>

  </ul>

 </li>

 </ul>

</div>

</body>

</html>

Copy after login

希望本文所述对大家的JavaScript程序设计有所帮助。

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template