一点一滴打造我们自己的web开发框架系列-1【web右键菜单的开发(上)】

  【概述】几乎每个企业都有自己的核心东西或说是框架性的东西,框架的好处是将我们经常要使用的功能,控件等包装一个个
易于使用的单元,就算是初学者也极其容易上手,减少项目的开发成本。因此框架的重要性和好处是不言而喻的。在我的这个系列
(一点一滴打造我们自己的web开发框架系列 )当中,我将自己在开发过程中用到的一些东西陆续公布出来,和大家一起交流学习。

  闲话少叙,我们在开发系统的过程中经常需要给web页面设定右键菜单,在这篇文章中我实现一个客户端的右键菜单,在下一篇
中我将把它包装成一个服务器控件。言归正传吧.......

  我们先来考虑下右键菜单的需求吧,首先我们需要构造函数,其次我们需要显示(show)和隐藏(hide),我们还需要添加菜单项
(add_MenuItem)和移除菜单项(remove_MenuItem),我们还需要将菜单设定到某个web页面上的dom元素(set_ContextMenu),

另外我们还需要初始化(initialize)函数来初始化一些属性和绑定一些事件,和dispose移除不再使用属性的值,最后为了让我们的菜单
能显示的漂亮一点,我们需要设定菜单项的样式(MenuItemStyle),分割栏的样式(SeparatorMenuItemStyle),及菜单容器的样式
(MenuStyle),以及鼠标滑过菜单项和滑出菜单项的样式。最后还需要每个菜单项的构造函数。

  知道需求后,我们来一步步实现。

构造函数:

代码

 

接下来实现上面提到的每个方法:

代码

 

再实现每个菜单项目的构造函数:

代码
function WebContextMenu.MenuItem(text, img, handler) {
    
this.Text = text;
    
this.Image = img;
    
this.Handler = handler;
}

WebContextMenu.MenuItem.prototype 
= {
    
}

 

完成后,我们客户端如何来调用呢,首先我们需要在aspx页面包含ScriptManager控件和jQuery.js,如果不是aspx页面,你需要自己手动将Microsoft.Ajax.js
和jquery.js包含进去(本人的癖好喜欢用这两个js库)。包含上两个js文件后,我们添加以下代码

html代码

代码
<div id="divSpan" style="color:Red;font-size:14px;font-weight:bold;height:123px;width:300px;background-color:#789ccd"></div>
 

js代码:

代码

 其中add,edit,del,outputExcel,inputExel为客户端js方法,不贴代码了。

如果你是想在页面初始化就绑定一个右键菜单(当然你也可以在某个控件的客户端事件中绑定右键菜单,随便你了)

代码
$(document).ready(function() {WebContextMenu1.set_ContextMenu('divSpan');});

 

这样一个简单的右键菜单就成了,截个图大家看看。当然你可以根据你实际项目的需要添加更多的方法,和修改样式。欢迎批评指正!在下一篇中我将其包装成服务器控件,可以通过服务器端来添加菜单,或者直接从工具栏拖到页面上方便使用。

图一:右键单击


图二:选择添加右键菜单,处理相应事件

posted @ 2009-11-30 16:52  落叶潇潇雨  阅读(3357)  评论(21编辑  收藏  举报