我在mxml中有一个列表。当用户长按列表中的项目时,我需要显示一个菜单。菜单将显示已按下项目的某些操作。
我还必须将按下的项目设为列表中的选定项目。所以我需要一个对列表的引用。我找不到正常的方式进入列表所以我这样做了:
var list:Object = event.currentTarget.parent.parent.parent.parent.parent
当然这很可怕。我正在寻找一种更好的方法来获得对列表的引用。
以下是我的代码:
<s:List id="catList" x="0" y="0" width="100%" height="100%" click="selectItemHandler(event)">
<s:itemRenderer>
<fx:Component>
<s:IconItemRenderer
styleName="labelFontStyle"
messageStyleName="descriptionFontStyle"
labelField="labelField"
messageField="descriptionField"
dataChange="onDataChange(event)"
mouseDown="onMouseDown(event)">
<fx:Script>
<![CDATA[
import mx.events.FlexEvent;
protected function onMouseDown(event:MouseEvent):void
{
try
{
var tg:Object = event.target;
var selectedItem:Object = event.currentTarget.data;
if (selectedItem != null)
{
// Here I need to set the selectedItem property of
// the owning list.
// I don't know how to get to the list so I did this.
var list:Object = event.currentTarget.parent.parent.parent.parent.parent;
list.selectedItem = selectedItem;
}
} catch (e:Error) {}
}
]]>
</fx:Script>
</s:IconItemRenderer>
</fx:Component>
</s:itemRenderer>
</s:List>
答案 0 :(得分:2)
我不确定但不会只是在itemrenderer的onMouseDown中设置所选属性吗?
selected = true;
如果没有,请检查这是否可以获得您的清单:
var myList:List = owner as List;
另一种方法是创建一个包含项目的自定义事件,并从itemrenderer中触发它。然后在列表中侦听该事件,并将selectedItem属性设置为您在事件中获得的项目