我的编程空间,编程开发者的网络收藏夹
学习永远不晚

js前端设计模式如何优化50%表单

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

js前端设计模式如何优化50%表单

本篇内容主要讲解“js前端设计模式如何优化50%表单”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“js前端设计模式如何优化50%表单”吧!

    表单校验

    背景

    假设我们正在编写一个注册页面,在点击注册按钮之时,有如下几条校验逻辑:

    • 用户名不能为空

    • 密码长度不能少于6位

    • 手机号码必须符合格式

    常规写法:

    const form = document.getElementById('registerForm');form.onsubmit = function () {  if (form.userName.value === '') {    alert('用户名不能为空');    return false;  }  if (form.password.value.length < 6) {    alert('密码长度不能少于6位');    return false;  }  if (!/^1[3|5|8][0-9]{9}$/.test(form.phoneNumber.value)) {    alert('手机号码格式不正确');    return false;  }  ...}

    这是一种很常见的代码编写方式,但它有许多缺点:

    • onsubmit 函数比较庞大,包含了很多 if-else 语句,这些语句需要覆盖所有的校验规则。

    • onsubmit 函数缺乏弹性,如果增加了一种新的校验规则,或者想把密码的长度从6改成8,我们都必须深入 obsubmit 函数的内部实现,这是违反开放-封闭原则的。

    • 算法的复用性差,如果在项目中增加了另外一个表单,这个表单也需要进行一些类似的校验,我们很可能将这些校验逻辑复制得漫天遍野。

    如何避免上述缺陷,更优雅地实现表单校验呢?

    策略模式介绍

    策略模式是一种行为设计模式, 它能让你定义一系列算法, 把它们一个个封装起来, 并使它们可以相互替换。

    真实世界类比

    js前端设计模式如何优化50%表单

    假如你需要前往机场。 你可以选择骑自行车、乘坐大巴或搭出租车。这三种出行策略就是广义上的“算法”,它们都能让你从家里出发到机场。你无需深入它们的内部实现细节,如怎么开大巴、公路系统如何确保你家到机场有通路等。你只需要了解这些策略的各自特点:所需要花费的时间与金钱,你就可以根据预算和时间等因素来选择其中一种策略。

    更广义的“算法”

    在实际开发中,我们通常会把算法的含义扩散开来,使策略模式也可以用来封装一系列的“业务规则”。只要这些业务规则指向的目标一致,并且可以被替换使用,我们就可以用策略模式来封装它们。

    策略模式的组成

    一个策略模式至少由两部分组成。

    第一个部分是一组策略类,策略类封装了具体的算法,并负责具体的计算过程。

    第二个部分是环境类 Context,Context 接受客户的请求,随后把请求委托给某一个策略类。

    利用策略模式改写

    定义规则(策略),封装表单校验逻辑:

    const strategies = {  isNonEmpty: function (value, errMsg) {    if (value === '') {      return errMsg;    }  },  minLenth: function (value, length, errMsg) {    if (value.length < length) {      return errMsg;    }  },  isMobile: function (value, errMsg) {    if (!/^1[3|5|8][0-9]{9}$/.test(value)) {      return errMsg;    }  }}

    定义环境类 Context,进行表单校验,调用策略:

    form.onsubmit = function () {const validator = new Validator();validator.add(form.userName, 'isNonEmpty', '用户名不能为空');validator.add(form.password, 'minLength:6', '密码长度不能少于6位');validator.add(form.phoneNumber, 'isMobile', '手机号码格式不正确');const errMsg = validator.start();if (errMsg) {alert(errMsg);return false;}}

    Validator 类代码如下:

    class Validator {constructor() {this.cache = [];}add(dom, rule, errMsg) {const arr = rule.split(':');this.cache.push(() => {const strategy = arr.shift();arr.unshift(dom.value);arr.push(errMsg);return strategies[strategy].apply(dom, arr);})}start() {for (let i = 0; i < this.cache.length; i++) {const msg = this.cache[i]();if (msg) return msg;}}}

    使用策略模式重构代码之后,我们消除了原程序中大片的条件分支语句。我们仅仅通过“配置”的方式就可以完成一个表单校验,这些校验规则也能在程序中任何地方复用,还能作为插件的形式,方便地移植到其他项目中。

    策略模式优缺点

    优点:

    • 可以有效地避免多重条件选择语句。

    • 开放-封闭原则完美支持,将算法封装在独立的 strategy 中,使得它们易于切换,易于理解,易于扩展。

    • 可以使算法复用在系统的其他地方,避免许多重复的复制粘贴工作。

    缺点:

    • 使用策略模式会在程序中增加许多策略类或策略对象

    • 要使用策略模式,必须了解所有的 strategy,了解它们的不同点,我们才能选择一个合适的 strategy。这是违反最少知识原则的。

    策略模式适合应用场景

    当你想使用对象中各种不同的算法变体, 并希望能在运行时切换算法时, 可使用策略模式。

    策略模式让你能够将对象关联至可以不同方式执行特定子任务的不同子对象, 从而以间接方式在运行时更改对象行为。

    当你有许多仅在执行某些行为时略有不同的相似类时, 可使用策略模式。

    策略模式让你能将不同行为抽取到一个独立类层次结构中, 并将原始类组合成同一个, 从而减少重复代码。

    如果算法在上下文的逻辑中不是特别重要, 使用该模式能将类的业务逻辑与其算法实现细节隔离开来。

    策略模式让你能将各种算法的代码、 内部数据和依赖关系与其他代码隔离开来。 不同客户端可通过一个简单接口执行算法, 并能在运行时进行切换。

    当类中使用了复杂条件运算符以在同一算法的不同变体中切换时, 可使用该模式。

    策略模式将所有继承自同样接口的算法抽取到独立类中, 因此不再需要条件语句。 原始对象并不实现所有算法的变体, 而是将执行工作委派给其中的一个独立算法对象。

    到此,相信大家对“js前端设计模式如何优化50%表单”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    js前端设计模式如何优化50%表单

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    js前端设计模式如何优化50%表单

    本篇内容主要讲解“js前端设计模式如何优化50%表单”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“js前端设计模式如何优化50%表单”吧!表单校验背景假设我们正在编写一个注册页面,在点击注册按钮
    2023-07-02

    如何实现网站Web端表单的交互式设计

    这篇文章主要介绍“如何实现网站Web端表单的交互式设计”,在日常操作中,相信很多人在如何实现网站Web端表单的交互式设计问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何实现网站Web端表单的交互式设计”的疑
    2023-06-10

    如何使用设计模式优化 PHP 函数的架构和性能?

    通过应用设计模式,例如单例模式、观察者模式和工厂模式,可以优化 php 函数的架构和性能,包括:单例模式:确保类只有一个实例,提高全局资源访问效率。观察者模式:允许对象通知多个观察者事件更改,提高事件响应效率。工厂模式:在运行时创建不同类型
    如何使用设计模式优化 PHP 函数的架构和性能?
    2024-04-25

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录