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

本文介绍了一种使Flex应用在加载时自动获取焦点的方法,通过简单的JavaScript实现,适用于IE和Firefox浏览器。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

默认情况下,一个浏览器里的Flex应用不能在加载时获取焦点。当一个应用开始启动,假设在里面有个login界面并希望用户名的输入框拥有焦点,就会特别让人沮丧。幸好,用一些简单的JavaScript语句可以办到。

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

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

Code:
  1. this.view.userNameTextInput.setFocus();

创建一个JavaScript来设置浏览器的焦点为你的Flex应用。在你的Flex project里的index.template.html文件里创建这个方法-只需要放在文件底部的closing HTML tag之前:

Code:
  1. <scripttype="text/javascript">
  2. functiononFlexInitialized()
  3. {
  4. //alert("onFlexInitialized");
  5. <!--Forcethebrowsertosetflexappwithfocus-->
  6. document.getElementById("${application}").focus();
  7. }
  8. </script>

接下来捕获应用程序的完成事件并调用我们建立的JS方法-我把Flex 3和4的用到的代码都写了出来:

Code:
  1. /**
  2. *Constructor.
  3. */
  4. publicfunctionAppController()
  5. {
  6. FlexGlobals.topLevelApplication.addEventListener(FlexEvent.APPLICATION_COMPLETE,onAppComplete);//Flex4
  7. //Application.application.addEventListener(FlexEvent.APPLICATION_COMPLETE,onAppComplete);//Flex3
  8. }
  9. /**
  10. *Handlestheapplicationcompleteevent.
  11. */
  12. protectedfunctiononAppComplete(e:FlexEvent):void
  13. {
  14. FlexGlobals.topLevelApplication.removeEventListener(FlexEvent.APPLICATION_COMPLETE,onAppComplete);//Flex4
  15. //Application.application.removeEventListener(FlexEvent.APPLICATION_COMPLETE,onAppComplete);//Flex3
  16. if(ExternalInterface.available)
  17. {
  18. ExternalInterface.call("onFlexInitialized");
  19. }
  20. }

这样就完成了。再次重申,这方法不适用于Safari和Chrome。这里是两个浏览器bug的缺陷日志-Chrome, Safari

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值