跳到主要内容
版本:v7

管理焦点

Ionic 在 InputSearchbarTextarea 等组件上提供了 setFocus API,允许开发者手动将焦点设置到某个元素上。应使用此 API 来替代 autofocus 属性,并在以下情况下调用:

  • 路由应用中,页面进入时的 ionViewDidEnter 生命周期事件。
  • 覆盖层(overlay)显示时的 didPresent 生命周期事件。
  • 原生 JavaScript 应用加载时的 appload 事件。
  • 用户手势或交互的结果。

为什么不使用 autofocus?

autofocus 属性是一个标准的 HTML 属性,允许开发者在页面加载时将焦点设置到某个元素上。此属性通常用于将焦点设置到页面上的第一个输入元素。然而,在路由应用中进行页面导航时,autofocus 属性可能会引发问题。这是因为 autofocus 属性会在页面加载时设置焦点,但在重新访问页面时却不会。更多关于 autofocus 属性的信息,请参阅 MDN Web 文档

平台限制

使用 setFocus API 时,需要注意以下平台限制:

  1. Android 要求在设置元素焦点之前必须有用户交互,例如用户轻点屏幕。
  2. 在移动版 Safari(iOS)上,交互性元素只有在用户手势(例如点击按钮后调用 setFocus)的结果下才能获得焦点。

基本用法

以下示例演示了如何在用户点击按钮时使用 setFocus API 来请求输入框焦点。

路由

开发者可以在页面进入时,使用 ionViewDidEnter 生命周期事件来设置元素焦点。

/* example.component.ts */
import { Component, ViewChild } from '@angular/core';
import { IonInput } from '@ionic/angular';

@Component({
selector: 'app-example',
templateUrl: './example.component.html',
})
export class ExampleComponent {
@ViewChild('input') input!: IonInput;

ionViewDidEnter() {
this.input.setFocus();
}
}

覆盖层

开发者可以在覆盖层显示时,使用 didPresent 生命周期事件来设置元素焦点。

<ion-modal>
<ion-input></ion-input>
</ion-modal>

<script>
const modal = document.querySelector('ion-modal');
modal.addEventListener('didPresent', () => {
const input = modal.querySelector('ion-input');
input.setFocus();
});
</script>