input使用以及源码解读

近期项目中使用的vux中的input,以及使用自定义校验规则和动态匹配错误提示,有时间记录下自己的使用经历和源码分析。希望大家多多指正,留言区发表自己宝贵的建议。 详解 列举官方文档中常用的几个属性的使用方法,代码如下

<group ref="group"> <x-input v-model="name" title="名字" placeholder="tell me your name" required :is-type="checkNameValid" @on-change="onValueChange"> <div slot="label"> <icon type="success"></icon> </div> </x-input> </group>

官方文档有详细的解释, required 属性表示此选项为必填, is-type 可以绑定一个函数,作为校验,这个函数得返回一个对象。格式如下

checkValid(name) { return { valid: name === '三只萌新', msg: '你不是萌新' } }

valid可以设置为你的校验规则,需要返回一个布尔值,msg是错误的提示信息。

vux本身写好几种校验方式,如果使用 email,china-name,china-mobile 这几种方式直接绑定字符串即可。

solt插槽如slot="label"用于自定义title,源码如下

<slot> <label :class="labelClass" :style="{width: labelWidth || $parent.labelWidth || labelWidthComputed, textAlign: $parent.labelAlign, marginRight: $parent.labelMarginRight}" v-if="title" v-html="title" :for="`vux-x-input-${uuid}`"></label> <inline-desc v-if="inlineDesc">{{ inlineDesc }}</inline-desc> </slot>

分析:class="labelClass"动态绑定样式以对象的形式返回一个{[className]:Boolean}的格式的对象

labelClass() { return { 'vux-cell-justify': this.$parent.labelAlign === 'justify' || this.$parent.$parent.labelAlign === 'justify' } }

input使用以及源码解读

 

同样的方式查看他父级是否有labelAlign属性,vux-cell-justify类名对应的样式没有应用。

使用场景

场景1

假设在一个提交页面,当我们提交时判断输入框中的值是否是符合我们的要求,如果不符合,给出错误提示,如果符合提交后将输入框中的数据清空。

需求:

如果还有停留在本页面我们需要将上一次的数据全部清空

问题:

我们需要初始化值,但是会发现如果我们设置了required后校验还是会触发。如何让数据清空并且让校验也清空。

解决方法:

文档中写了reset可以重置输入框值,清除错误信息

使用方式:

在x-input外层的group标签上绑定ref来访问子组件。因此我们可以通过 this.$refs.group.$children获取到input组件集合并且可以使用组件中定义的reset方法

如果你的项目中已经安装了vux可以通过安装查找node_modules文件夹中vux安装包路径为 vux/src/components/x-input/index.vue 文件 reset方法源码如下:

reset(value = '') { this.dirty = false this.currentValue = value this.firstError = '' this.valid = true }

回到我们的业务逻辑中当我们点击提交按钮时代码如下

onSubmitClick() { if (!this.isInvalid) { this.$refs.group.$children.forEach(child => { child.reset() }) } else { // 展示提示信息 this.isShowToast = true }

本以为这样就可以清空数据了,没想到点击按钮时数据是清空了,但是还是有报错图标显示。

input使用以及源码解读

 

通过 vue-devtools可以看到

input使用以及源码解读

valid的值为false查看vux源码查看涉及到valid代码如下

validate() { // ...省略与本次无关的校验方法 if (!this.currentValue && this.required) { this.valid = false this.errors.required = '必填哦' this.getError() return if (typeof this.isType === 'function') { /* 取出自定义函数中的校验结果 是一个Boolean checkNameValid(name) { return { valid: name === '三只萌新', msg: '你不是萌新' } } */ const validStatus = this.isType(this.currentValue) this.valid = validStatus.valid if (!this.valid) { // 如果校验值无效将自定义校验的msg赋值给errors对象下的format this.errors.format = validStatus.msg this.forceShowError = true this.getError() return } else { // 如果校验值有效则将error对象下的format删除 delete this.errors.format } // 如果都符合将valid赋值为有效 this.valid = true } }

validate函数校验当前是否有值,是否为必填, 如果当前值的校验方式是函数,将校验结果赋值给valid 。如果valid是false则将自定义的msg统一存储在errors对象下, errors是用来存储不同类型的错误信息 。 然后执行getError函数

getError() { let key = Object.keys(this.errors)[0] this.firstError = this.errors[key] console.log('firstError' + this.firstError) }

Object.keys(this.errors)返回errors对象下的所有可枚举属性,并且取第一个作为键名,取出对于的值赋值给firstError ,firstError是提示框文字

<toast v-model="showErrorToast" type="text" :time="600">{{ firstError }}</toast>

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/751e5f53ec0061c6741fae9fd790738f.html