六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 31|回复: 0

设置Flex在加载应用的时候获取焦点

[复制链接]

升级  51.33%

33

主题

33

主题

33

主题

秀才

Rank: 2

积分
127
 楼主| 发表于 2013-1-29 09:27:48 | 显示全部楼层 |阅读模式
默认情况下,一个浏览器里的Flex应用不能在加载时获取焦点。当一个应用开始启动,假设在里面有个login界面并希望用户名的输入框拥有焦点,就会特别让人沮丧。幸好,用一些简单的JavaScript语句可以办到。

注意:这不能用在Safari, Chrome或其它使用Webkit的浏览器中。如果你用的IE和Firefox则没问题。为了示范,让我们假设我们需要用户名的输入框在Flex app加载的时候获得焦点。

首先,设置聚焦到用户名输入区 - 假设一个ViewMediator是这样做的:

Code:
this.view.userNameTextInput.setFocus();   
创建一个JavaScript来设置浏览器的焦点为你的Flex应用。在你的Flex project里的index.template.html文件里创建这个方法-只需要放在文件底部的closing HTML tag之前:
Code:<script type="text/javascript">    function onFlexInitialized()    {       //alert("onFlexInitialized");        <!-- Force the browser to set flex app with focus -->        document.getElementById("${application}").focus();    }    </script>    接下来捕获应用程序的完成事件并调用我们建立的JS方法-我把Flex 3和4的用到的代码都写了出来:
Code:/**   * Constructor.   */   public function AppController()    {            FlexGlobals.topLevelApplication.addEventListener(FlexEvent.APPLICATION_COMPLETE, onAppComplete); // Flex 4            //Application.application.addEventListener(FlexEvent.APPLICATION_COMPLETE, onAppComplete); // Flex 3    }    /**   * Handles the application complete event.   */   protected function onAppComplete(e:FlexEvent):void   {            FlexGlobals.topLevelApplication.removeEventListener(FlexEvent.APPLICATION_COMPLETE, onAppComplete); // Flex 4            //Application.application.removeEventListener(FlexEvent.APPLICATION_COMPLETE, onAppComplete); // Flex 3            if(ExternalInterface.available)            {                    ExternalInterface.call("onFlexInitialized");            }    }    这样就完成了。再次重申,这方法不适用于Safari和Chrome。这里是两个浏览器bug的缺陷日志-Chrome, Safari
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表