Input
优质
小牛编辑
124浏览
2023-12-01
1.5.0 新增
输入框组件。支持使用v-model
对数据双向绑定,支持一键清空内容。
示例
基本用法
使用
v-model
对输入内容双向绑定。<cube-input v-model="value" ></cube-input>
export default { data() { return { value: '' } } }
控制最大长度
通过 watch 组件的 value 值的长度可实现手工控制值长度。
<cube-input v-model="value"></cube-input>
export default { data() { return { value: '' } }, watch: { value(newV) { if (newV.length > 10) { newV = newV.slice(0, 10) this.$nextTick(() => { this.value = newV }) } } } }
上述代码就是控制输入内容长度不得超过10位。
清空按钮
可通过
clearable
配置清空按钮。在 1.11.0 版本之前
clearable
的值是布尔类型的,表示是否展示清除按钮;在 1.11.0 版本之后
clearable
可配置为布尔类型,还可以配置为对象。<cube-input v-model="value" :clearable="clearable" ></cube-input>
export default { data() { return { value: '', clearable: { visible: true, blurHidden: true } } } }
clearable
配置的对象可以包含两个 key 值:visible
和blurHidden
分别代表是否展示以及当 Input 元素离焦的时候是否隐藏。密码配置
可通过
eye
设置密码眼睛。<cube-input v-model="value" :placeholder="placeholder" :type="type" :maxlength="maxlength" :readonly="readonly" :disabled="disabled" :autofocus="autofocus" :autocomplete="autocomplete" :eye="eye" ></cube-input>
export default { data() { return { value: '', placeholder: '请输入内容', type: 'password', readonly: true, maxlength: 100, disabled: true, autofocus: true, autocomplete: true, eye: { open: true, reverse: false } } } }
如同上边展示的,除了上述配置,还支持原生 Input 元素的大部分配置。
Props 配置
参数 | 说明 | 类型 | 可选值 | 默认值 |
---|---|---|---|---|
type | input类型 | String | text/number/password/date | text |
v-model | 绑定的值 | String | - | 空 |
disabled | 禁用状态 | Boolean | true/false | false |
readonly | 只读状态 | Boolean | true/false | false |
maxlength | 最大输入长度 | Number | - | 60 |
placeholder | 占位文本 | String | - | 空 |
autofocus | 自动对焦 | Boolean | true/false | false |
autocomplete | 自动补全 | Boolean | true/false | false |
clearable | 是否使用清空按钮,1.11.0 后可配置为对象形式 {visible: true, blurHidden: true} ,其中 visible 控制是否显示,blurHidden 控制离焦后是否隐藏 | Boolean/Object1.11.0+ | true/false/{visible: true, blurHidden: true} | false |
eye | 默认 false,密码眼睛不可见;如果是 true ,则相当于配置为对象 { open: true, reverse: false } 。对象形式表示使用密码眼睛。其中 open 控制眼睛张开还是闭合。reverse 控制密码可见和眼睛开闭是否相反。 | Boolean/Object | true/false/{open: true/false, reverse: true/false} | false |
插槽
名字 | 说明 |
---|---|
prepend | 前置内容 |
append | 后置内容 |
事件
事件名 | 说明 | 参数 |
---|---|---|
focus | 输入框聚焦后触发此事件,如果禁用状态,则不触发 | e - 事件对象 |
blur | 输入框失焦后触发此事件 | e - 事件对象 |
change | 绑定值改变且输入框失去焦点后触发 | e - 事件对象 |
input | 绑定值变化时触发 | 更新后的绑定值 |
实例方法
方法名 | 说明 |
---|---|
focus1.12.10+ | 获得焦点 |
blur1.12.10+ | 离焦 |