title: Input 输入框 description: 用于单行文本信息输入。 spline: form
全局引入,在 miniprogram 根目录下的app.json
中配置,局部引入,在需要引入的页面或组件的index.json
中配置。
"usingComponents": {
"t-input": "tdesign-miniprogram/input/input"
}
Tips: 请确保开发者工具为打开状态。导入开发者工具后,依次执行:npm i > 构建npm包 > 勾选 "将JS编译成ES5"
基础输入框
{{ base }}
带字数限制输入框
{{ maxlength }}
带操作输入框
{{ suffix }}
带图标输入框
{{ prefix }}
特定类型输入框
{{ special }}
输入框状态
{{ status }}
信息超长状态
{{ label }}
内容位置
{{ align }}
竖排样式
{{ layout }}
非通栏样式
{{ banner }}
标签外置样式
{{ bordered }}
自定义样式文本框
{{ custom }}
名称 | 类型 | 默认值 | 描述 | 必传
-- | -- | -- | -- | --
style | Object | - | 样式 | N
custom-style | Object | - | 样式,一般用于开启虚拟化组件节点场景 | N
adjust-position | Boolean | true | 键盘弹起时,是否自动上推页面 | N
align | String | left | 文本内容位置,居左/居中/居右。可选项:left/center/right | N
allow-input-over-max | Boolean | false | 超出 maxlength
或 maxcharacter
之后是否允许继续输入 | N
always-embed | Boolean | false | 强制 input 处于同层状态,默认 focus 时 input 会切到非同层状态 (仅在 iOS 下生效) | N
auto-focus | Boolean | false | (即将废弃,请直接使用 focus )自动聚焦,拉起键盘 | N
borderless | Boolean | false | 是否开启无边框模式 | N
clear-trigger | String | always | 清空图标触发方式,仅在输入框有值时有效。可选项:always / focus | N
clearable | Boolean / Object | false | 是否可清空,默认不启动。值为 true
表示使用默认清空按钮,值为 Object
表示透传至 icon
| N
confirm-hold | Boolean | false | 点击键盘右下角按钮时是否保持键盘不收起 | N
confirm-type | String | done | 设置键盘右下角按钮的文字,仅在type='text'时生效。
具体释义:send
右下角按钮为“发送”;search
右下角按钮为“搜索”;next
右下角按钮为“下一个”;go
右下角按钮为“前往”;done
右下角按钮为“完成”。
小程序官方文档。可选项:send/search/next/go/done | N
cursor | Number | - | 必需。指定 focus 时的光标位置 | Y
cursor-color | String | #0052d9 | 光标颜色。iOS 下的格式为十六进制颜色值 #000000,安卓下的只支持 default 和 green,Skyline 下无限制 | N
cursor-spacing | Number | 0 | 指定光标与键盘的距离,取 input 距离底部的距离和 cursor-spacing 指定的距离的最小值作为光标与键盘的距离 | N
disabled | Boolean | undefined | 是否禁用输入框 | N
error-message | String | - | 已废弃。错误提示文本,值为空不显示(废弃属性,如果需要,请更为使用 status 和 tips) | N
focus | Boolean | false | 获取焦点 | N
format | Function | - | 指定输入框展示值的格式。TS 类型:InputFormatType
type InputFormatType = (value: InputValue) => string
。详细类型定义 | N
hold-keyboard | Boolean | false | focus时,点击页面的时候不收起键盘 | N
label | String / Slot | - | 左侧文本。通用类型定义 | N
layout | String | horizontal | 标题输入框布局方式。可选项:vertical/horizontal | N
maxcharacter | Number | - | 用户最多可以输入的字符个数,一个中文汉字表示两个字符长度。maxcharacter
和 maxlength
二选一使用 | N
maxlength | Number | -1 | 用户最多可以输入的文本长度,一个中文等于一个计数长度。默认为 -1,不限制输入长度。maxcharacter
和 maxlength
二选一使用 | N
password | Boolean | false | 已废弃。是否是密码类型(已废弃,请更为使用 type 指定输入框类型) | N
placeholder | String | undefined | 占位符 | N
placeholder-class | String | input-placeholder | 指定 placeholder 的样式类 | N
placeholder-style | String | - | 必需。指定 placeholder 的样式 | Y
prefix-icon | String / Object / Slot | - | 组件前置图标。值为字符串表示图标名称,值为 Object
类型,表示透传至 icon
。通用类型定义 | N
readonly | Boolean | undefined | 只读状态 | N
safe-password-cert-path | String | - | 安全键盘加密公钥的路径,只支持包内路径 | N
safe-password-custom-hash | String | - | 安全键盘计算 hash 的算法表达式,如 md5(sha1('foo' + sha256(sm3(password + 'bar'))))
| N
safe-password-length | Number | - | 安全键盘输入密码长度 | N
safe-password-nonce | String | - | 安全键盘加密盐值 | N
safe-password-salt | String | - | 安全键盘计算 hash 盐值,若指定custom-hash 则无效 | N
safe-password-time-stamp | Number | - | 安全键盘加密时间戳 | N
selection-end | Number | -1 | 光标结束位置,自动聚集时有效,需与 selection-start 搭配使用 | N
selection-start | Number | -1 | 光标起始位置,自动聚集时有效,需与 selection-end 搭配使用 | N
size | String | medium | 已废弃。输入框尺寸。可选项:small/medium。TS 类型:'medium' \| 'small'
| N
status | String | default | 输入框状态。可选项:default/success/warning/error | N
suffix | String / Slot | - | 后置图标前的后置内容。通用类型定义 | N
suffix-icon | String / Object / Slot | - | 后置文本内容。值为字符串则表示图标名称,值为 Object
类型,表示透传至 icon
。通用类型定义 | N
tips | String / Slot | - | 输入框下方提示文本,会根据不同的 status
呈现不同的样式。通用类型定义 | N
type | String | text | 输入框类型。可选项:text/number/idcard/digit/safe-password/password/nickname | N
value | String / Number | - | 输入框的值。TS 类型:InputValue
type InputValue = string \| number
。详细类型定义 | N
default-value | String / Number | undefined | 输入框的值。非受控属性。TS 类型:InputValue
type InputValue = string \| number
。详细类型定义 | N
名称 | 参数 | 描述
-- | -- | --
blur | (value: InputValue)
| 失去焦点时触发
change | (value: InputValue, cursor: number, keyCode: number)
| 输入框值发生变化时触发;cursor 为光标位置;
clear | - | 清空按钮点击时触发
click | (trigger: InputTrigger)
| 0.32.0
。点击事件。详细类型定义。type InputTrigger = 'suffix' \| 'suffix-icon';
enter | (value: InputValue)
| 回车键按下时触发
focus | (value: InputValue)
| 获得焦点时触发
keyboardheightchange | (height: number, duration: number)
| 键盘高度发生变化的时候触发此事件
nicknamereview | (pass: boolean, timeout: boolean)
| 用户昵称审核完毕后触发,仅在 type 为 "nickname" 时有效
validate | (detail: { error?: 'exceed-maximum' \| 'below-minimum' })
| 字数超出限制时触发
类名 | 描述 -- | -- t-class | 根节点样式类 t-class-clearable | 清空按钮样式类 t-class-input | 输入框样式类 t-class-label | 标签样式类 t-class-prefix-icon | 前置图标样式类 t-class-suffix | 后置样式类 t-class-suffix-icon | 后置图标样式类 t-class-tips | 提示样式类
组件提供了下列 CSS 变量,可用于自定义样式。
名称 | 默认值 | 描述 -- | -- | -- --td-input-align-items | center | - --td-input-bg-color | @bg-color-container | - --td-input-border-color | @component-stroke | - --td-input-border-left-space | 32rpx | - --td-input-border-right-space | 0 | - --td-input-default-text-color | @text-color-primary | - --td-input-default-tips-color | @text-color-placeholder | - --td-input-disabled-text-color | @text-color-disabled | - --td-input-error-text-color | @error-color | - --td-input-error-tips-color | @error-color | - --td-input-label-max-width | 5em | - --td-input-label-min-width | 2em | - --td-input-label-text-color | @text-color-primary | - --td-input-placeholder-text-color | @text-color-placeholder | - --td-input-placeholder-text-font-size | @font-size-m | - --td-input-prefix-icon-color | @text-color-primary | - --td-input-success-text-color | @success-color | - --td-input-success-tips-color | @success-color | - --td-input-suffix-icon-color | @text-color-placeholder | - --td-input-suffix-text-color | @text-color-primary | - --td-input-vertical-padding | 32rpx | - --td-input-warning-text-color | @warning-color | - --td-input-warning-tips-color | @warning-color | -