• 【前端设计模式】之建造者模式


    建造者模式是一种创建型设计模式,它允许你按照特定的步骤构建复杂对象。该模式将对象的构造过程与其表示分离,使得同样的构造过程可以创建不同的表示。

    建造者模式特性

    1. 将复杂对象的构建过程分解为多个简单步骤,使得代码更加可读、可维护。
    2. 允许你通过改变构造过程中的步骤顺序或者配置来创建不同的对象。
    3. 隐藏了复杂对象的创建细节,使得客户端代码与具体对象的创建过程解耦。

    应用示例

    1. 创建复杂表单

    假设我们需要创建一个包含多个输入字段和验证规则的表单。使用建造者模式可以将表单的构建过程分解为多个步骤,每个步骤负责添加一个字段和相应的验证规则。这样一来,我们可以根据需要自由组合字段和验证规则,而不需要关心具体的构建细节。

     
    
    1. class FormBuilder {
    2. constructor() {
    3. this.fields = [];
    4. }
    5. addField(label, type, required) {
    6. this.fields.push({ label, type, required });
    7. return this;
    8. }
    9. addValidation(validationFn) {
    10. const field = this.fields[this.fields.length - 1];
    11. field.validation = validationFn;
    12. return this;
    13. }
    14. build() {
    15. return new Form(this.fields);
    16. }
    17. }
    18. class Form {
    19. constructor(fields) {
    20. this.fields = fields;
    21. }
    22. validate() {
    23. for (const field of this.fields) {
    24. if (field.required && !field.value) {
    25. return false;
    26. }
    27. if (field.validation && !field.validation(field.value)) {
    28. return false;
    29. }
    30. }
    31. return true;
    32. }
    33. }
    34. // 使用建造者模式创建表单
    35. const form = new FormBuilder()
    36. .addField("Username", "text", true)
    37. .addValidation(value => value.length >= 6)
    38. .addField("Password", "password", true)
    39. .addValidation(value => value.length >= 8)
    40. .build();
    41. // 验证表单
    42. if (form.validate()) {
    43. console.log("Form is valid");
    44. } else {
    45. console.log("Form is invalid");
    46. }

    首先,定义了一个FormBuilder类作为建造者,它有一个fields数组用于存储表单字段。

    addField方法用于向fields数组中添加一个新的表单字段,包括标签(label)、类型(type)和是否必填(required)。在添加字段后,该方法返回建造者对象本身,以便进行链式调用。

    addValidation方法用于向最后一个添加的表单字段添加验证函数(validationFn)。该验证函数将在表单验证时执行,判断字段的值是否满足特定条件。添加验证函数后,该方法同样返回建造者对象本身。

    build方法用于创建并返回一个新的Form对象,其中包含了通过建造者配置的所有表单字段。

    接下来,定义了一个Form类作为最终的对象,它接收一个包含表单字段的数组作为构造函数的参数,并将该数组存储为fields属性。

    validate方法用于验证表单是否有效。它遍历fields数组中的每个字段,首先检查是否为必填字段且未填写,然后检查是否设置了验证函数且验证失败。如果有任何一个条件不满足,则返回false表示表单无效。如果所有条件都满足,则返回true表示表单有效。

    最后,通过实例化FormBuilder并使用链式调用的方式添加表单字段和验证函数,然后调用build方法创建了一个新的Form对象。接下来,调用validate方法验证表单的有效性,并根据结果输出相应的消息。

    2. 构建复杂的UI组件

    在前端开发中,我们经常需要构建复杂的UI组件,其中包含多个子组件和配置选项。使用建造者模式可以将组件的构建过程分解为多个步骤,每个步骤负责添加一个子组件或者配置选项。这样一来,我们可以根据需要自由组合子组件和配置选项,而不需要关心具体的构建细节。

     
    
    1. class ComponentBuilder {
    2. constructor() {
    3. this.children = [];
    4. this.props = {};
    5. }
    6. addChild(child) {
    7. this.children.push(child);
    8. return this;
    9. }
    10. setProps(props) {
    11. this.props = props;
    12. return this;
    13. }
    14. build() {
    15. return new Component(this.children, this.props);
    16. }
    17. }
    18. class Component {
    19. constructor(children, props) {
    20. this.children = children;
    21. this.props = props;
    22. }
    23. render() {
    24. // 渲染组件
    25. }
    26. }
    27. // 使用建造者模式构建复杂的UI组件
    28. const component = new ComponentBuilder()
    29. .addChild(new ChildComponent1())
    30. .addChild(new ChildComponent2())
    31. .setProps({ color: "red", size: "large" })
    32. .build();
    33. // 渲染组件
    34. component.render();

    首先,定义了ComponentBuilder类,它用于构建Component对象。ComponentBuilder具有以下方法:

    • addChild(child): 添加一个子组件到children数组中,并返回this以便链式调用。
    • setProps(props): 设置组件的属性,并将传递的props对象赋值给this.props,并返回this
    • build(): 构建并返回一个新的Component对象,该对象使用this.childrenthis.props进行初始化。

    接下来,定义了Component类,它表示要构建的组件。Component具有以下方法:

    • constructor(children, props): 构造函数接受一个children数组和一个props对象,分别赋值给this.childrenthis.props
    • render(): 这是一个占位方法,可以根据具体需求实现组件的渲染逻辑。

    最后,使用建造者模式来构建和配置复杂的UI组件。通过链式调用ComponentBuilder的方法来逐步构建和配置组件。

    优缺点

    优点
    1. 将复杂对象的构建过程分解为多个简单步骤,使得代码更加可读、可维护。
    2. 允许你通过改变构造过程中的步骤顺序或者配置来创建不同的对象。
    3. 隐藏了复杂对象的创建细节,使得客户端代码与具体对象的创建过程解耦。
    缺点
    1. 建造者模式会增加代码量,因为需要定义多个类来表示不同的构建步骤和最终产品。
    2. 当需要创建的对象较少或者构建过程简单时,使用建造者模式可能会显得繁琐。

    总结

    建造者模式是一种创建型设计模式,它将复杂对象的构建过程与其表示分离,使得同样的构造过程可以创建不同的表示。在前端开发中,可以使用建造者模式来构建复杂的表单、UI组件等。该模式的优点是使代码更加可读、可维护,并且允许根据需要自由组合构建步骤和配置选项。然而,使用建造者模式会增加代码量,并且在对象较少或者构建过程简单时可能显得繁琐。

  • 相关阅读:
    HCS 中的一些概念(二)
    Linux基础知识——(1)基本指令
    网络系统管理 - Windows Server AD域安全策略
    AcWing 234 放弃测试
    使用Ant Design Vue的Table组件,解决点击任意内容详情,点击返回分页器页数默认回到第一页的问题
    【GNN报告】华为诺亚实验室周敏:曲率视角下的图数据建模与分析
    TensorFlow学习:使用官方模型进行图像分类、使用自己的数据对模型进行微调
    表的内连接
    Java实用类(五) -Math类和指定范围的随机数
    centos中安装的goland配置sdk报错:所选的目录不是Go SDK的有效主路经
  • 原文地址:https://blog.csdn.net/wanghongpu9305/article/details/133882121