键盘
在构建移动应用和渐进式 Web 应用(PWA)时,定制和处理屏幕键盘的存在是开发者经常面临的两个难题。本指南将介绍在应用中管理屏幕键盘的各种可用工具。
inputmode
inputmode 属性允许开发者指定可以输入到输入框中的数据类型。这将提示浏览器显示包含与用户可能输入内容相关按键的键盘。例如,inputmode="email" 会显示带有 @ 键的键盘,并针对电子邮件输入进行其他优化。
由于 inputmode 是一个全局属性,它不仅可以用于常规输入元素,还可以用于 Ionic 组件,如 ion-input 和 ion-textarea。
要求 特 定数据类型的输入应使用 type 属性。例如,需要电子邮件的输入应使用 type="email",而不是指定 inputmode。这是因为输入的数据始终将是电子邮件格式。另一方面,如果输入接受电子邮件或用户名,则使用 inputmode="email" 是合适的,因为输入的数据并不总是电子邮件地址。
有关可接受值的列表,请参阅 inputmode 文档。
使用示例
inputmode 属性在运行 Chrome 66+ 和 iOS Safari 12.2+ 的设备上受支持:https://caniuse.com/#search=inputmode
enterkeyhint
enterkeyhint 属性允许开发者指定“Enter”键应显示的操作标签或图标类型。使用 enterkeyhint 可以让用户知道点击“Enter”键时会发生什么。这里指定的值取决于用户正在进行的操作上下文。例如,如果用户正在搜索框中输入,开发者应确保该输入具有 enterkeyhint="search"。
由于 enterkeyhint 是一个全局属性,它不仅可以用于常规输入元素,还可以用于 Ionic 组件,如 ion-input 和 ion-textarea。
有关可接受值的列表,请参阅 enterkeyhint 标准。
使用示例
enterkeyhint 属性在运行 Chrome 77+ 和 iOS Safari 13.4+ 的设备上受支持。
深色模式
默认情况下,键盘主题由操作系统决定。例如,如果在 iOS 上启用了深色模式,即使应用的 CSS 中没有深色主题,应用中的键盘也会以深色主题显示。
在移动浏览器或作为 PWA 运行应用时,无法强制键盘以特定主题显示。
在 Capacitor 或 Cordova 中运行应用时,可以强制键盘以特定主题显示。有关此配置的更多信息,请参阅 Capacitor 键盘文档。
隐藏辅助栏
当运行 任何类型的基于 Web 的应用程序时,iOS 会在键盘上方显示一个辅助栏。这允许用户移动到下一个或上一个输入框,以及关闭键盘。
在移动浏览器或作为 PWA 运行应用时,无法隐藏辅助栏。
在 Capacitor 或 Cordova 中运行应用时,可以隐藏辅助栏。有关此配置的更多信息,请参阅 Capacitor 键盘文档。
键盘生命周期事件
检测屏幕键盘的存在对于调整输入框位置非常有用,否则输入框可能会被键盘遮挡。对于 Capacitor 和 Cordova 应用,开发者通常依赖原生键盘插件来监听键盘生命周期事件。对于在移动浏览器或作为 PWA 运行的应用,开发者可以在支持的情况下使用 Visual Viewport API。Ionic Framework 封装了这两种方法,并在 window 上触发 ionKeyboardDidShow 和 ionKeyboardDidHide 事件。ionKeyboardDidShow 的事件负载包含以像素为单位的键盘高度近似值。
使用示例
- JavaScript
- Angular
- Angular (Standalone)
- React
- Vue
window.addEventListener('ionKeyboardDidShow', event => {
const { keyboardHeight } = event;
// 使用键盘高度做一些操作,例如将输入框移动到键盘上方。
});
window.addEventListener('ionKeyboardDidHide', () => {
// 将输入框移回原始位置
});
import { Platform } from '@ionic/angular';
...
constructor(private platform: Platform) {
this.platform.keyboardDidShow.subscribe(event => {
const { keyboardHeight } = event;
// 使用键盘高度做一些操作,例如将输入框移动到键盘上方。
});
this.platform.keyboardDidHide.subscribe(() => {
// 将输入框移回原始位置
});
}
import { Platform } from '@ionic/angular/standalone';
...
constructor(private platform: Platform) {
this.platform.keyboardDidShow.subscribe(event => {
const { keyboardHeight } = event;
// 使用键盘高度做一些操作,例如将输入框移动到键盘上方。
});
this.platform.keyboardDidHide.subscribe(() => {
// 将输入框移回原始位置
});
}
import { useKeyboardState } from '@ionic/react-hooks/keyboard';
...
const { isOpen, keyboardHeight } = useKeyboardState();
// 使用键盘高度做一些操作,例如将输入框移动到键盘上方
import { useKeyboard } from '@ionic/vue';
import { watch } from 'vue';
...
const { isOpen, keyboardHeight } = useKeyboard();
watch(keyboardHeight, () => {
console.log(`键盘是否打开: ${isOpen.value}, 键盘高度: ${keyboardHeight.value}`);
});
对于在移动浏览器或作为 PWA 运行的应用,键盘生命周期事件仅在 Chrome 62+ 和 iOS Safari 13.0+ 中受支持。