- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我试图在 VueJS 中编写一些相当简单的验证逻辑,偶然发现了一个看似简单的问题,但我很难找到合适的解决方案。
在我的 Vue 组件上,我有一个数据对象,它是一个简单的 Form 类实例。
export default {
data: function () {
return {
form: new Form([
{ email: '' },
{ password: '' },
]),
}
},
methods: {
handleSubmit () {
// A callback in which an API request is performed using something like Axios.
this.form.submit((data) => performApiRequest(data));
},
}
这个 Form 类有一个 errors 属性,它包含表单中输入字段的错误。为了确定给定字段是否存在错误,添加了“hasError”方法。
export default class Form {
constructor (fields = {}) {
this.fields = fields;
this.errors = {};
}
hasError (error) { return this.errors.hasOwnProperty(error); }
submit (action) {
action(this.fields)
.catch((error) => {
this.errors = error.response.data.errors;
});
}
}
在组件的模板中,我们以这种方式检查错误:
<input type="email" v-model="form.email">
<span class="error" v-if="form.hasError('email')">{{ form.errors.email }}</span>
这一切都非常有效,但是每当我的表单中的输入值之一发生变化时,就会为所有字段触发 hasError
方法。因此,如果我们添加 20 个输入字段,具有 20 个错误范围,则在任何输入字段中键入单个字符时,此方法将被调用 20 次。
这是有道理的,因为 hasError 不是计算属性,因此不具备计算属性所具有的缓存优势。
考虑到我希望 Form 类可跨多个组件重用,我很难理解如何重构它以利用某种形式的缓存。
如何以可重用的方式实现此功能?
最佳答案
您可以使 Form 的每个字段成为具有值和错误键的对象。
{ value: "thevalue", error: "some error" }
然后在你的模板中,使用
<input type="email" v-model="form.email.value">
<span class="error" v-if="form.email.error">{{ form.email.error }}</span>
这还将允许您进行每个字段的验证或其他行为
{
value: "thevalue",
error: "some error",
validations: [<array of validation functions>], // like minLength/maxLength,
// built-in validations for some common types
// like email or isDigits or alphanumeric etc
type: "email"
}
关于javascript - 如何重构数据对象以允许其内部的计算属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54504210/
你能比较一下属性吗 我想禁用文本框“txtName”。有两种方式 使用javascript,txtName.disabled = true 使用 ASP.NET, 哪种方法更好,为什么? 最佳答案 我
Count 属性 返回一个集合或 Dictionary 对象包含的项目数。只读。 object.Count object 可以是“应用于”列表中列出的任何集合或对
CompareMode 属性 设置并返回在 Dictionary 对象中比较字符串关键字的比较模式。 object.CompareMode[ = compare] 参数
Column 属性 只读属性,返回 TextStream 文件中当前字符位置的列号。 object.Column object 通常是 TextStream 对象的名称。
AvailableSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。 object.AvailableSpace object 应为 Drive 
Attributes 属性 设置或返回文件或文件夹的属性。可读写或只读(与属性有关)。 object.Attributes [= newattributes] 参数 object
AtEndOfStream 属性 如果文件指针位于 TextStream 文件末,则返回 True;否则如果不为只读则返回 False。 object.A
AtEndOfLine 属性 TextStream 文件中,如果文件指针指向行末标记,就返回 True;否则如果不是只读则返回 False。 object.AtEn
RootFolder 属性 返回一个 Folder 对象,表示指定驱动器的根文件夹。只读。 object.RootFolder object 应为 Dr
Path 属性 返回指定文件、文件夹或驱动器的路径。 object.Path object 应为 File、Folder 或 Drive 对象的名称。 说明 对于驱动器,路径不包含根目录。
ParentFolder 属性 返回指定文件或文件夹的父文件夹。只读。 object.ParentFolder object 应为 File 或 Folder 对象的名称。 说明 以下代码
Name 属性 设置或返回指定的文件或文件夹的名称。可读写。 object.Name [= newname] 参数 object 必选项。应为 File 或&
Line 属性 只读属性,返回 TextStream 文件中的当前行号。 object.Line object 通常是 TextStream 对象的名称。 说明 文件刚
Key 属性 在 Dictionary 对象中设置 key。 object.Key(key) = newkey 参数 object 必选项。通常是 Dictionary 
Item 属性 设置或返回 Dictionary 对象中指定的 key 对应的 item,或返回集合中基于指定的 key 的&
IsRootFolder 属性 如果指定的文件夹是根文件夹,返回 True;否则返回 False。 object.IsRootFolder object 应为&n
IsReady 属性 如果指定的驱动器就绪,返回 True;否则返回 False。 object.IsReady object 应为 Drive&nbs
FreeSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。只读。 object.FreeSpace object 应为 Drive 对象的名称。
FileSystem 属性 返回指定的驱动器使用的文件系统的类型。 object.FileSystem object 应为 Drive 对象的名称。 说明 可
Files 属性 返回由指定文件夹中所有 File 对象(包括隐藏文件和系统文件)组成的 Files 集合。 object.Files object&n
我是一名优秀的程序员,十分优秀!