1

我在使用 TabNavigator 时遇到问题,它总是发送错误:

TypeError: Error #1009: Cannot access a property or method of a null object reference.
at mx.containers::TabNavigator/keyDownHandler()[/Users/justinmclean/Documents/ApacheFlex4.11.0/frameworks/projects/mx/src/mx/containers/TabNavigator.as:903]

示例代码:

<?xml version="1.0" encoding="utf-8"?>
<s:WindowedApplication xmlns:fx="http://ns.adobe.com/mxml/2009" 
                   xmlns:s="library://ns.adobe.com/flex/spark" 
                   xmlns:mx="library://ns.adobe.com/flex/mx" applicationComplete="init(event)">
<fx:Script>
    <![CDATA[
        import mx.events.FlexEvent;

        protected function init(event:FlexEvent):void
        {
            stage.addEventListener(KeyboardEvent.KEY_DOWN, handleKeyDown);
        }

        public function handleKeyDown(event:KeyboardEvent):void
        {
            if(event.keyCode == Keyboard.F1){
                if(currentState=="State1"){
                    currentState = "setting";
                }else{
                    currentState = "State1";
                }
            }
        }
    ]]>
</fx:Script>
<fx:Declarations>
    <!-- Place non-visual elements (e.g., services, value objects) here -->
</fx:Declarations>
<s:states>
    <s:State name="State1"/>
    <s:State name="setting"/>
</s:states>

<s:BorderContainer left="0" right="0" top="0" bottom="0" includeIn="setting">
<mx:TabNavigator id="TabNavigator" left="10" right="10" top="110" bottom="10" creationPolicy="all">
    <!-- General Tab -->
    <s:NavigatorContent id="generaltab" width="100%" height="100%" label="General">
        <s:Group id="generalcontainer">
        </s:Group>
    </s:NavigatorContent>
    <!-- Screen Tab -->
    <s:NavigatorContent id="screentab" width="100%" height="100%" label="Screen">
        <s:Group id="screencontainer" width="100%" height="100%">
        </s:Group>
    </s:NavigatorContent>
    <!-- Playlist Tab -->
    <s:NavigatorContent id="playlisttab" width="100%" height="100%" label="Playlist">
        <s:Group id="playlistcontainer">    
        </s:Group>
    </s:NavigatorContent>
</mx:TabNavigator>
    </s:BorderContainer>
</s:WindowedApplication>

当我按 F1 时,它会跳转到设置页面。这将显示选项卡导航器。再次按 F1 将其隐藏。

基本上,重复显示和隐藏选项卡导航器是没有问题的。但是,如果我在隐藏选项卡导航器之前单击任何选项卡,当我尝试通过按键盘上的 F1 再次显示选项卡导航器时,它会发送错误,如上所示。

如何解决/防止错误发生?

谢谢你。

4

2 回答 2

2

看起来您偶然发现了 SDK 中的一个错误(坦率地说,这让我有点担心,因为这意味着一些事件侦听器没有被正确处理)。

查看错误发生的来源:

override protected function keyDownHandler(event:KeyboardEvent):void
{
    if (focusManager.getFocus() == this)
    {
        // Redispatch the event from the TabBar so that it can handle it.
        tabBar.dispatchEvent(event);
    }
}

发生的情况是,当您从State1to开始时settingTabNavigator最初不在 displayList 上(您正在通过 添加它includeIn),因此它没有focusManager. 这是完全正常的;不正常的是该keyDownHandler方法是针对当前不在 displayList 上的组件执行的。这最终会导致该空指针异常,因为没有focusManager执行该方法的时间。
当 TabNavigator 的父级被移除时,框架似乎没有清理事件侦听器。当 TabNavigator 本身被添加/删除时,它确实可以正常工作includeIn,所以幸运的是,解决方法非常简单:

<s:BorderContainer includeIn="setting">
    <mx:TabNavigator id="TabNavigator" includeIn="setting" creationPolicy="all">

您可能希望在Apache Flex JIRA中注册此错误

于 2013-12-15T16:38:00.937 回答
1

我刚刚找到了一种防止错误发生的方法。也就是说,TabNavigator.stage.focus=null;在将状态更改回之前添加State1

于 2013-12-16T02:02:40.413 回答