input

您所在的位置:网站首页 uni交易所有app吗 input

input

2024-05-15 10:38| 来源: 网络整理| 查看: 265

# input

单行输入框。

html规范中input不仅是输入框,还有radio、checkbox、时间、日期、文件选择功能。在uni-app规范中,input仅仅是输入框。其他功能uni-app有单独的组件或API:radio组件 、checkbox组件 、时间选择 、日期选择 、图片选择 、视频选择 、多媒体文件选择(含图片视频) 、通用文件选择 。

# 属性说明 属性名 类型 默认值 说明 平台差异说明 value String 输入框的初始内容 type String text input 的类型 有效值 text-content-type String 文本区域的语义,根据类型自动填充 有效值 仅 App-nvue-iOS 支持 password Boolean false 是否是密码类型 H5和App写此属性时,type失效 placeholder String 输入框为空时占位符 placeholder-style String 指定 placeholder 的样式 placeholder-class String "input-placeholder" 指定 placeholder 的样式类,注意页面或组件的style中写了scoped时,需要在类名前写/deep/ 抖音小程序、飞书小程序、快手小程序不支持 disabled Boolean false 是否禁用 maxlength Number 140 最大输入长度,设置为 -1 的时候不限制最大长度 cursor-spacing Number 0 指定光标与键盘的距离,单位 px 。取 input 距离底部的距离和 cursor-spacing 指定的距离的最小值作为光标与键盘的距离 App、微信小程序、百度小程序、QQ小程序、京东小程序 focus Boolean false 获取焦点。 H5、App需要点击按钮获取焦点的,必须使用@touchend.prevent="onTap"阻止键盘收起默认事件才能获取焦点关于软键盘弹出的逻辑说明,小程序、nvue需使用组件的 focus()、blur() 方法控制焦点 confirm-type String done 设置键盘右下角按钮的文字,仅在 type="text" 时生效。有效值 微信小程序、App、H5、快手小程序、京东小程序 confirm-hold Boolean false 点击键盘右下角按钮时是否保持键盘不收起 App(3.3.7+)、H5 (3.3.7+)、微信小程序、支付宝小程序、百度小程序、QQ小程序、京东小程序 cursor Number 指定focus时的光标位置 cursor-color String 光标颜色 微信小程序 3.1.0+、H5(4.0+)、App-Vue(4.0+) selection-start Number -1 光标起始位置,自动聚集时有效,需与selection-end搭配使用 selection-end Number -1 光标结束位置,自动聚集时有效,需与selection-start搭配使用 adjust-position Boolean true 键盘弹起时,是否自动上推页面 App-Android(vue 页面 softinputMode 为 adjustResize 时无效,使用 x5 内核时无效)、微信小程序、百度小程序、QQ小程序、京东小程序 auto-blur Boolean false 键盘收起时,是否自动失去焦点 App-Vue 3.0.0+ ignoreCompositionEvent Boolean true 是否忽略组件内对文本合成系统事件的处理。为 false 时将触发 compositionstart、compositionend、compositionupdate 事件,且在文本合成期间会触发 input 事件 App-vue (3.4.4+)、H5 (3.4.4+)、App-nvue不支持 always-embed Boolean false 强制 input 处于同层状态,默认 focus 时 input 会切到非同层状态 (仅在 iOS 下生效) 微信小程序 2.10.4+ hold-keyboard Boolean false focus时,点击页面的时候不收起键盘 微信小程序 2.8.2+ safe-password-cert-path String 安全键盘加密公钥的路径,只支持包内路径 微信小程序 2.18.0+ safe-password-length Number 安全键盘输入密码长度 微信小程序 2.18.0+ safe-password-time-stamp Number 安全键盘加密时间戳 微信小程序 2.18.0+ safe-password-nonce String 安全键盘加密盐值 微信小程序 2.18.0+ safe-password-salt String 安全键盘计算 hash 盐值,若指定custom-hash 则无效 微信小程序 2.18.0+ safe-password-custom-hash String 安全键盘计算 hash 的算法表达式,如 md5(sha1('foo' + sha256(sm3(password + 'bar')))) 微信小程序 2.18.0+ random-number Boolean false 当 type 为 number, digit, idcard 数字键盘是否随机排列 支付宝小程序 1.9.0+ controlled Boolean false 是否为受控组件。为 true 时,value 内容会完全受 setData 控制 支付宝小程序 1.9.0+ always-system Boolean false 是否强制使用系统键盘和 Web-view 创建的 input 元素。为 true 时,confirm-type、confirm-hold 可能失效 支付宝小程序 2.7.3+ inputmode String "text" 是一个枚举属性,它提供了用户在编辑元素或其内容时可能输入的数据类型的提示。有效值 H5(3.6.16+)、App-vue(3.6.16+) @input EventHandle 当键盘输入时,触发input事件,event.detail = {value} 差异见下方 Tips @focus EventHandle 输入框聚焦时触发,event.detail = { value, height },height 为键盘高度 仅微信小程序、京东小程序、App(2.2.3+) 、QQ小程序支持 height @blur EventHandle 输入框失去焦点时触发,event.detail = {value: value} 快手小程序不支持 @confirm EventHandle 点击完成按钮时触发,event.detail = {value: value}  快手小程序不支持 @keyboardheightchange eventhandle 键盘高度发生变化的时候触发此事件,event.detail = {height: height, duration: duration} 微信小程序基础库2.7.0+、App 3.1.0+

Tips

input 事件处理函数可以直接 return 一个字符串,将替换输入框的内容。仅微信小程序支持。 如果遇到 value 属性设置不生效的问题参考:组件属性设置不生效解决办法 input 组件上有默认的 min-height 样式,如果 min-height 的值大于 height 的值那么 height 样式无效。 微信小程序 cursor-color 属性在iOS下的格式为十六进制颜色值 #000000,安卓下只支持 default 和 green,Skyline 下无限制。 # type 有效值 值 说明 平台差异说明 text 文本输入键盘 number 数字输入键盘 均支持,App平台、H5平台 3.1.22 以下版本 vue 页面在 iOS 平台显示的键盘包含负数和小数。 idcard 身份证输入键盘 微信、支付宝、百度、QQ小程序、快手小程序、京东小程序 digit 带小数点的数字键盘 均支持,App平台、H5平台 vue 页面在 iOS 平台显示的键盘包含负数(原生键盘不支持负号)。 tel 电话输入键盘 safe-password 密码安全输入键盘 微信小程序 nickname 昵称输入键盘 微信小程序

注意事项

小程序平台,number 类型只支持输入整型数字。微信开发者工具上体现不出效果,请使用真机预览。 如果需要输入浮点型数字,请使用 digit 类型。 小程序端input在置焦时,会表现为原生控件,此时会层级变高。如需前端组件遮盖input,需让input失焦,或使用cover-view等覆盖原生控件的方案,参考 。具体来讲,阿里小程序的input为text且置焦为原生控件;微信、头条、QQ所有input置焦均为原生控件;百度小程序置焦时仍然是非原生的。也可以参考原生控件 文档 input组件若不想弹出软键盘,可设置为disabled placeholder-style指定样式类font-size单位为rpx时,抖音小程序、飞书小程序、快手小程序不支持,可使用uni.upx2px()将rpx单位值转换成px。 # text-content-type 有效值

仅 App-nvue-iOS 支持

值 说明 oneTimeCode 一次性验证码,常用于短信验证码输入 # confirm-type 有效值

弹出软键盘的右下角按钮的文字。

值 说明 平台差异说明 send 右下角按钮为“发送” 微信、支付宝、百度小程序、快手小程序、京东小程序、app-nvue、app-vue和h5(2.9.9+,且要求设备webview内核Chrome81+、Safari13.7+) search 右下角按钮为“搜索” next 右下角按钮为“下一个” 微信、支付宝、百度小程序、快手小程序、京东小程序、app-nvue、app-vue和h5(2.9.9+,且要求设备webview内核Chrome81+、Safari13.7+) go 右下角按钮为“前往” done 右下角按钮为“完成” 微信、支付宝、百度小程序、快手小程序、京东小程序、app-nvue、app-vue和h5(2.9.9+,且要求设备webview内核Chrome81+、Safari13.7+) App平台的vue页面及 H5平台 的弹出键盘使用的是浏览器控制的键盘,在Chrome81+、Safari13.7+之前,键盘右下角文字只能设置完成和搜索,从Chrome81+、Safari13.7+起支持设置发送、下一个。 App平台涉及聊天的建议使用nvue,一方面因为app-vue控制键盘右下角按键文字为“发送”对webview内核有要求,另一方面聊天记录如使用scroll-view,过长的内容在app-vue上会有性能问题。 # inputmode 有效值

新增于 uni-app 3.6.16+ inputmode是html规范后期更新的内容。各家小程序还未支持此属性。

在符合条件的高版本webview里,uni-app的web和app-vue平台中可使用本属性。

值 说明 none 无虚拟键盘。在应用程序或者站点需要实现自己的键盘输入控件时很有用。 text 使用用户本地区域设置的标准文本输入键盘。 decimal 小数输入键盘,包含数字和分隔符(通常是“ . ”或者“ , ”),设备可能也可能不显示减号键。 numeric 数字输入键盘,所需要的就是 0 到 9 的数字,设备可能也可能不显示减号键。 tel 电话输入键盘,包含 0 到 9 的数字、星号(*)和井号(#)键。表单输入里面的电话输入通常应该使用 。 search 为搜索输入优化的虚拟键盘,比如,返回键可能被重新标记为“搜索”,也可能还有其他的优化。 email 为邮件地址输入优化的虚拟键盘,通常包含"@"符号和其他优化。表单里面的邮件地址输入应该使用 。 url 为网址输入优化的虚拟键盘,比如,“/”键会更加明显、历史记录访问等。表单里面的网址输入通常应该使用 。

注意事项

inputmode 兼容性:Chrome >= 66、Edge >= 79、Firefox >= 95、Chrome Android >= 66、Firefox for Android >= 79、Safari on iOS >= 12.2、WebView Android >= 66 input组件有 inputmode 和 type、comfirm-tye 3个相似的属性,它们的区别详解如下: type:在 uni-app 和小程序中仅仅是输入框,定义 input 的工作方式,此值决定可输入什么值。比如 number 只能输入数字。 comfirm-type:定义键盘右下角按键的文字 inputmode:inputmode 属性是当使用某些值时会对键盘所作出的优化。 同时使用 inputmode 和 comfirm-type 时,若设值冲突,键盘右下角按键类型由 comfirm-type 决定 type 属性和 inputmode 属性并不冲突 # App平台iOS端软键盘上方横条去除方案

app-vue在iOS上,webview中的软键盘弹出时,默认在软键盘上方有一个横条,显示着:上一项、下一项和完成等按钮。 如不想显示这个横条,可以配置softinputNavBar: 'none'

配置方式,在 pages.json 中某个页面或全局配置 style

"app-plus": { "softinputNavBar": "none" } 如需使用js动态设置softinputNavBar this.$scope.$getAppWebview().setStyle({ softinputNavBar: 'none' }) //this.$scope.$getAppWebview()相当于html5plus里的plus.webview.currentWebview()。在uni-app里vue页面直接使用plus.webview.currentWebview()无效

如果是nvue页面,iOS默认就没有键盘上方的横条,无需任何设置。

# 关于软键盘弹出的逻辑说明

App平台软键盘弹出有 adjustResize|adjustPan 两种模式,默认为 adjustPan 模式,小程序平台只支持 adjustPan 模式,H5平台因不同浏览器而异

adjustResize:软键盘弹出时,webview窗体高度挤压。屏幕高度=webview窗体高度+软键盘高度 adjustPan:软键盘弹出时,webview窗体高度不变,但窗体上推,以保证输入框不被软键盘盖住

配置方式,在 pages.json 中配置 style

"app-plus": { "softinputMode": "adjustResize" }

注意

adjustResize模式在Android App上,弹起键盘和收回键盘时,因为要重设webview窗体高度,可能会在个别安卓机型闪现灰屏或漏出下层页面内容。 小程序端在 input 聚焦期间,避免使用 css 动画。 H5平台只能在用户交互时修改 focus 生效。 如果遇到 focus 属性设置不生效的问题参考:组件属性设置不生效解决办法 如需禁止点击其他位置收起键盘的默认行为,可以监听touch事件并使用prevent修饰符(仅支持App、H5,其他平台可以通过设置focus来使输入框重新获取焦点),例如在确认按钮上使用:@touchend.prevent="onTap" # 关于软键盘收起的逻辑说明 Android上在软键盘弹出后,点击back或点击非置焦区域可收起软键盘。 iOS上如果软键盘上方有带有“完成”的横条,则需要点完成才能收起键盘;如果没有软键盘上方横条,则点击非input/textarea区域即可收起软键盘

以上为默认逻辑,uni-app同时提供了隐藏软键盘的api:uni.hideKeyboard()

# App平台原生输入框的说明

在app平台,有titleNView配置的searchinput原生输入框和plus.nativeObj.view的drawinput。这两种方式的输入框都是原生的,不是webview里的。

原生输入框在iOS上不会有软键盘上方的横条 原生输入框一样受配置的adjustPan|adjustResize模式影响

input示例 查看演示

以下示例代码,来自于hello uni-app项目 ,推荐使用HBuilderX,新建uni-app项目,选择hello uni-app模板,可直接体验完整示例。

Template

Script

可自动聚焦的input 键盘右下角按钮显示为搜索 控制最大输入长度的input 实时获取输入值:{{inputValue}} 控制输入的input 控制键盘的input 数字输入的input 密码输入的input 带小数点的input 身份证输入的input 控制占位符颜色的input 带清除按钮的输入框  可查看密码的输入框  # 扩展 uni ui提供了easyinput组件,提供了常用的封装,可搭配uni-forms组件,支持表单验证、支持各种常用设置。详见 uni ui提供了combox组件,可选可输入,常用词免输入。详见 uni ui提供了搜索框ui组件,插件市场还有封装好的页面模板。详见 。云端一体搜索模板功能完善,推荐使用:https://ext.dcloud.net.cn/plugin?id=3851 uni-app插件市场有输入文字后自动提示候选的组件,可搜索 autocomplete 查看。 插件市场有各种类型的模拟键盘,比如车牌键盘、身份证键盘,可去插件市场搜索 键盘 。


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3