npm 包 @jaspero/ng2-form-builder 使用教程

简介

@jaspero/ng2-form-builder 是一款 Angular 2+ 的表单构建器的 npm 包。通过它,我们可以快速构建出强大的表单,并通过一些简单的配置就能完成表单的验证。在本文中,我们将深入讲解如何使用 @jaspero/ng2-form-builder,通过示例代码演示其用法,以及为读者带来学习和指导意义。

安装

在开始之前,我们需要通过 npm 安装 @jaspero/ng2-form-builder

--- ------- -------------------------

接着,在 app.module.ts 中引入 JasperoFormBuilderModule 并添加到 imports 中。

------ - -------- - ---- ----------------
------ - ------------ - ---- ------------------
------ - ------------------- - ---- -----------------

------ - ------------------------ - ---- ----------------------------

-----------
  ------------- ---
  -------- -
    -------------
    --------------------
    ------------------------
  --
  ---------- ---
  ---------- --------------
--
------ ----- --------- - -

基本用法

在本节中,我们将演示如何创建一个简单的表单。

  1. 导入 JasperoFormBuilderService
------ - ------------------------- - ---- ----------------------------
  1. 声明局部变量 form
---- - ----------------------------
  ----- -----
  ------ ---- --------------------- -------------------
  --------- -----
  ---------------- ---- -------------------------------------
---

以上代码声明了一个包含四个字段的表单,分别是 nameemailpasswordconfirmPassword。其中,namepassword 的初始值为空字符串,emailconfirmPassword 则有相应的验证规则。

  1. 在 HTML 中添加表单元素。
----- ------------------ -----------
  -------
    -----
    ------ ----------- -----------------------
  --------

  -------
    ------
    ------ ------------ ------------------------
    ----- -------------------------------------------------
      ----- -- --------
    -------
    ----- ----------------------------------------------
      ------- ----- ------
    -------
  --------

  -------
    ---------
    ------ --------------- ---------------------------
  --------

  -------
    ------- ---------
    ------ --------------- ----------------------------------
    ----- ----------------------------------------------------------
      --------- ---- -----
    -------
  --------

  ------- ------------- -----------------------------------------
-------

注意到,在 HTML 中,我们必须将表单和表单字段与 form 相关联。在此基础上,我们还可以根据字段的验证状态,动态显示或隐藏错误信息。

高级用法

在本节中,我们将演示如何应用高级的表单配置和验证规则。

配置自定义方法

@jaspero/ng2-form-builder 支持任意定制的验证方法。在本例中,我们将展示如何在表单中使用自定义的验证方法。

  1. 导入 CustomValidators
------ - ---------------- - ---- ----------------------------
  1. 声明自定义验证方法。
-------- ----------------- -------- ----------- -
  ------ --------- ----------------- - ----- -------- --- - - ---- -- -
    ----- ------ - ------------- --- ------
    ------ ------ - ---- - - ----------- - ----- - --
  --
-

该方法检查给定控件的值是否等于指定值,并返回一个有 key 值为 checkValue 的对象。

  1. 使用自定义验证方法。
---- - ----------------------------
  ----- -----
  ---- ---- ------------------
  ------ ---- --------------------- -------------------
  --------- -----
  ---------------- ---- -------------------------------------
---

在表单的定义中,我们添加了一个名为 age 的字段,并使用 checkValue 方法对其进行验证。

  1. 在 HTML 中显示错误消息。
-------
  ----
  ------ ------------- ----------------------
  ----- -------------------------------------------------
    ---- -- -- ----- ---
  -------
--------

配置自定义控件

在某些情况下,我们需要在表单中使用自定义控件。在本例中,我们将演示如何使用自定义控件从而扩展表单功能。

  1. 声明自定义控件组件。
------ - ---------- ----- - ---- ----------------
------ - --------------------- ----------------- - ---- -----------------

------------
  --------- ---------------
  ---------- -
    -
      -------- ------------------
      ------------ ---------------------
      ------ ----
    -
  --
  --------- -
    ------ ----------- --------------------
  -
--
------ ----- -------------------- ---------- -------------------- -
  -------- ------ -------
  --------- ------- ---- -- -----

  ------------- --

  ----------------- ---- -
    ---------- - ------
  -

  -------------------- ---- -
    ------------- - ---
  -

  --------------------- ---- --

  ----------------------------- -------- --
-

该组件是一个简单的文本输入框,并实现 ControlValueAccessor 接口。

  1. 在表单中使用自定义控件。
---- - ----------------------------
  ----- -----
  ------- ----
---

在表单的定义中,我们添加了一个名为 custom 的字段,并在 HTML 中添加了一个自定义的 custom-input 控件。

  1. 在 HTML 中添加自定义控件。
-------
  -------
  ------------- ----------------------------------------
--------

配置动态控件

在某些情况下,我们需要动态添加和删除表单字段。在本例中,我们将展示如何通过 @jaspero/ng2-form-builder 实现动态添加和删除表单字段。

  1. 导入 FormBuilderFormGroup.
------ - ------------ --------- - ---- -----------------
  1. 声明表单字段数目的初始值。
--------------- - --

在这里,我们定义了表单的初试字段数目为 2

  1. 在 HTML 中添加动态按钮。
------- ------------------------ --------------
------- ------------------------------ --------------

通过调用 addFieldremoveField 方法,我们可以动态地添加和删除表单字段。

  1. 实现添加和删除表单字段的逻辑。
---- - --- --------------
---- - ---------
---- - -------

------------------- ------------ ------------ --

---------- -
  -----------------------

  ------------------------------------------------------------ ---------------------------- ----------------------
-

------------- -
  -- --------------------- - -- -
    ----------------------------------------------------------------
    -----------------------
  -
-

上述代码中,我们通过定义名为 name 和类型为 text 的控件,使用 form.addControl 方法添加了一个新的表单字段。同时,通过 form.removeControl 方法删除了最后一个表单字段。

结论

在本文中,我们向读者展示了如何使用 @jaspero/ng2-form-builder,通过示例代码演示其用法,以及为读者带来学习和指导意义。@jaspero/ng2-form-builder 是一个非常实用的 Angular 2+ 表单构建器,具有很高的可定制性和扩展性,值得我们深入学习和使用。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/60066bc5967216659e24438f


猜你喜欢

  • npm 包 @jaredhanson/make-node 使用教程

    简介 @jaredhanson/make-node 是一个用于构建 Node.js Native Addon 的简单、易用、灵活的工具。它提供了一组命令行工具,以及一些简单的配置和规则,可以帮助你快速...

    4 年前
  • npm 包 @jazmon/require-env-vars 使用教程

    什么是 @jazmon/require-env-vars 包? 在开发前端应用程序时,环境变量是非常重要的一个因素。环境变量可以帮助开发人员在不同的环境中配置和管理应用程序的不同方面,例如数据库连接字...

    4 年前
  • npm 包 @jzetlen/bowserify 使用教程

    在前端开发过程中,我们常常需要使用 JavaScript 的模块化打包工具进行开发,其中最常用的是 npm 包管理工具和其插件。本文将介绍一款基于 npm 的 @jzetlen/bowserify,它...

    4 年前
  • npm 包 drag-drop.min.js 使用教程

    什么是 drag-drop.min.js? drag-drop.min.js 是一个基于 JavaScript 的 npm 包,用于处理拖放操作。它提供了一套简易的 API,可以让您轻松地将拖动操作应...

    4 年前
  • npm 包 @jmac18/epoch 使用教程

    什么是 @jmac18/epoch @jmac18/epoch 是一个可视化时间范围选择组件,适用于前端开发项目。它提供了强大的时间选择功能,可以在项目中轻松使用。

    4 年前
  • npm 包 drawing.min.js 使用教程

    在前端开发中,我们经常需要使用绘图工具来展示数据。而 drawing.min.js 是一个轻量级、易于使用的 npm 包,可以帮助我们快速创建各种类型的图形。本教程将向您展示如何使用 drawing....

    4 年前
  • npm 包 @jmfirth/lit-html-redux 使用教程

    在前端开发中,我们常常需要使用状态管理库来管理应用中的数据。Redux 是一个流行的状态管理库,但它通常需要大量的样板代码来完成基本的功能。同时,Lit-html 是一个高效的 DOM 更新库,能够保...

    4 年前
  • npm 包 @jworkshop/loadimage 使用教程

    前言 随着 Web 技术的快速发展,图像的处理和使用越来越频繁和重要。而前端工程师在开发过程中,也需要经常使用到图片的加载和处理。在这个时候,我们就需要使用一些工具来简化这些操作的过程。

    4 年前
  • npm 包 @jp928/react-native-circular-action-menu 使用教程

    前言 @jp928/react-native-circular-action-menu 是一个 React Native 的 npm 包,它通过提供一个圆形动作菜单来帮助您实现界面的美化和交互效果。

    4 年前
  • npm 包 "@joakimbeng/yml-reader" 使用教程

    前言 在 Web 开发中,我们经常需要读取一些 YAML 文件来进行数据渲染或其他操作。但是,JavaScript 并没有原生支持 YAML 文件的解析,因此我们需要借助一些第三方工具来实现这个功能。

    4 年前
  • npm 包 @jnupeter/unirest 使用教程

    前言 在前端开发中,经常需要发起网络请求,以获得后端数据或与后台进行交互。而在 JavaScript 中发起网络请求最常用的方法就是使用 Ajax,而如今我们也可以使用更加简单易用、功能更丰富的 np...

    4 年前
  • Java选择排序

    Java基础实例程序 在这个示例中,我们创建一个java程序,实现使用选择排序对数组元素进行排序。 在选择排序算法中,搜索最低的元素并将其排列到适当的位置。用下一个最小的数字交换当前元素。

    4 年前
  • Java插入排序

    Java基础实例程序 下面我们创建一个java程序,实现使用插入排序对数组元素进行排序。 插入排序对于小元素是有好处的,因为排序大量元素它需要更多的时间。 让我们来看看一个简单的java程...

    4 年前
  • Java气泡排序

    Java基础实例程序 在教程中,将创建一个java程序,使用冒泡排序对数组元素排序。 气泡排序算法也被称为最简单的排序算法。 在冒泡排序算法中,数组从第一个元素遍历到最后一个元素。

    4 年前
  • Java阿姆斯壮数(armstrongnumber) 实例

    Java基础实例程序 Java中的阿姆斯壮数(armstrongnumber) 定义:阿姆斯壮数(armstrongnumber) 是等于其数字的立方数之和的数字,例如:0,1,153,370...

    4 年前
  • Java阶乘实例

    Java基础实例程序 Java中的阶乘程序:n的阶乘是所有正整数的乘积。 n的因子由n!来表示。 例如: -- - ------- - -- -- - --------- - --- ...

    4 年前
  • Java回文实例

    Java基础实例程序 Java中的回文数定义:回文数是反向后与原数字也是相同的数字(即:从左边读和从右边读过来都是同一个数字)。 例如,545,151,3454,343,171,4884都是回...

    4 年前
  • Java素数实例

    Java基础实例程序 质数(prime number)又称素数,有无限个。质数定义是:在大于1的自然数中,除了1和它本身以外不再有其他因数的数称为质数。例如,2,3,5,7,11,13,17 ...

    4 年前
  • Java斐波那契数列实例

    Java基础实例程序 在斐波那契数列中,下一个数字是前两个数字的总和,例如:0,1,1,2,3,5,8,13,21,34,55等。斐波那契数列的前两个数字是0和1,第三个数字是前两个数字的和,...

    4 年前
  • npm 包 @javiercejudo/tap 使用教程

    简介 npm 是一个常用的 JavaScript 包管理器,提供了许多有用的包供前端开发者使用。@javiercejudo/tap 就是其中一个非常实用的包,它提供了一种方便的方式来使用单元测试框架 ...

    4 年前

相关推荐

    暂无文章