input或textarea标签的inputmode属性
inputmode介绍
inputmode全局属性为具有屏幕键盘的设备向浏览器提供提示,以帮助它们在用户选择input或textarea元素时决定要显示哪个键盘。与更改type表单类型不同,inputmode不会改变浏览器解释输入的方式,它只是指示浏览器显示哪个键盘,该属性适用于iOS的Safari和Android的Chrome。
inputmode属性值
inputmode 全局属性 是一个枚举属性,它提供了用户在编辑元素或其内容时可能输入的数据类型的提示。它可以是以下值:
"none"
没有虚拟键盘; 当应用程序或站点实现自己的键盘输入控件时,这很有用。
"text"
用户当前区域设置的标准文本输入键盘。
"decimal"
小数字输入键盘。
<input type="text" inputmode="decimal">
设置为decimal值的inputmode导致iOS发生细微变化,其中键盘看起来与tel值完全相同,但会用简单的十进制(.)替换+*键。另一方面,这对Android没有影响,它只使用数字键盘。
"numeric"
数字输入键盘,比如接受短信验证码的使用场景:
<input type="text" inputmode="numeric">"tel"
电话键盘输入,包括数字0到9,星号(“*”)和磅(“#”)键。你也可以使用表单输入<input type="tel">。
<input type="text" inputmode="tel">"search"
为搜索输入优化的虚拟键盘。例如,返回键可以被重新标记为“搜索”,并且可以存在其他优化。
"email"
为输入电子邮件地址而优化的虚拟键盘; 通常这包括“@”字符以及其他优化。通常应使用需要输入电子邮件地址的表单输入<input type="email">。
"url"
专为输入网址而优化的键盘。例如,这可能使“/”键更加突出。增强功能还可以包括历史记录访问等。请求URL的表单输入通常应该使用<input type="url">。
兼容性
H5移动端推荐使用该属性,兼容截图如下:

总结
如果未设置此属性,则其默认值为"text",表示应使用区域设置的标准文本输入键盘。
其实对于email, tel, url 之流,还是推荐使用对应的原生的输入框实现,基本上不存在需要使用 inputmode 属性实现的场景:
<input type="email">
<input type="tel">
<input type="url">
<input type="search">本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!