flex中Menubar组件dataprovider的后台数据获取方法

M对于<mx:MenuBar/>提供的有关资料非常的少,对于直接编码生成MENU的方法,用户选择某一菜单,会触发一个Change事件,然后可以通过该事件的event.menuItem.attributes.attribute来访问所选的菜单属性。
例如:

<mx:Script>

function changeEvt(event){    var menuItem=event.menuItem;    alert(menuItem.attributes.label); }
</mx:Script>
<mx:MenuBar id=”menuBar1″

change="changeEvt(event)" >     <mx:dataProvider>        <mx:XML>           <menuitem label="MenuItem A" >              <menuitem label="L1" />               <menuitem label="L2" />           </menuitem>           <menuitem label="MB" />           <menuitem label="MC" />        </mx:XML>     </mx:dataProvider>  </mx:MenuBar>

但是位于如果该MENUBAR是通过设置MenuBar标签的DataProvider属性来自动生成的,以上方法并不能获取到MenuItem的label,那么相应的捆绑到该MENUITEM的属性如何获取呢?
MM官方的文挡并没有提到方法,起码我没有找到,通过<Inspact/>我发现在ChangeEvent.MenuItem有一个backingObject,该对象包含了捆绑到该MenuItem的所有相应属性,那么问题的解决方法就很显然了。

<mx:Script>

function changeEvt(event){    var menuItem=event.menuItem;    alert(menuItem.backingObject.label); }
</mx:Script>
<mx:XML id=”menuDS1″

source="menuSrc.xml"   change="changeEvt(event)" />

menuSrc.xml 文件内容如下:

<node label=”File”>

<node label="Load" />
<node label="Save" />
<node label="Expand" />
<node label="Exit" />

</node>

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章