Flex右击功能实现

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" minWidth="955" minHeight="600"
creationComplete="init()"
>
<mx:Script>
import flash.net.navigateToURL;

import mx.controls.Alert;


internal var authorItem:ContextMenuItem;
internal var mobileItem:ContextMenuItem;
internal var mailItem:ContextMenuItem
internal var blogItem:ContextMenuItem;


//右键菜单事件
internal function init():void{
//创建一个右键菜单对象
var contextMenu:ContextMenu=new ContextMenu();
//隐藏指定的 ContextMenu对象内置选项
contextMenu.hideBuiltInItems();
//创建菜单选项
authorItem=new ContextMenuItem("作者:***");
mobileItem=new ContextMenuItem("手机:183****9798");
mailItem=new ContextMenuItem("Email:11******99@qq.com");
blogItem=new ContextMenuItem("Blog:http://http://my.csdn.net/my/mycsdn");

//将子菜单系添加到子菜单中
contextMenu.customItems.push(authorItem);
contextMenu.customItems.push(qqItem);
contextMenu.customItems.push(mailItem);
contextMenu.customItems.push(blogItem);

//为每个子菜单项添加监听事件
blogItem.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT,menuItemHandler);
authorItem.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT,menuItemHandler);
qqItem.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT,menuItemHandler);
mailItem.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT,menuItemHandler);

//为菜单设置监听事件
contextMenu.addEventListener(ContextMenuEvent.MENU_SELECT,menuHandler);

//将该菜单赋值给当前应用环境
this.contextMenu=contextMenu;
}

//菜单监听处理函数
internal function menuHandler(evt:ContextMenuEvent):void{
trace("menu");




//子菜单项监听处理函数
internal function menuItemHandler(evt:ContextMenuEvent):void{
//获取事件源,斌将其转化为ContextMenuItem
var item:ContextMenuItem=ContextMenuItem(evt.currentTarget);
var caption:String=item.caption;
switch(caption)
{
case blogItem.caption:
{
//若为blog地址,则请求到该地址
navigateToURL(new URLRequest("http://http://my.csdn.net/my/mycsdn"),"_blank");
break;
}
default:
{
Alert.show(caption,"您的选择");
break;
}
}
}




</mx:Script>
  
  
  </mx:Application>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值