IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> v-formly - 一个让你不用画UI就可以构建create/edit页面的库 -> 正文阅读

[JavaScript知识库]v-formly - 一个让你不用画UI就可以构建create/edit页面的库

写在前面

v-formly是vue的动态(JSON驱动)表单库。通过JSON的形式生成表单模板,一份表单简单修改即可多处复用!使您能够快速开发表单页面,相比编写传统的html form表单,使用JSON形式定义表单能够极大的提高了开发效率。目前支持Vue 2.x & Ant Design of Vue v1

支持的功能

以下列出了v-formly的主要功能点,其他细节请参考文档

  1. 支持使用JSON定义表单结构;
  2. 支持v-model双向绑定;
  3. 支持水平垂直行内三种布局;
  4. 支持Ajv内置的校验以及自定义数据校验(同步校验和异步校验);
  5. 支持自定义表单提交按钮以及内置提交按钮;
  6. 支持内置的15+组件以及自定义组件;
  7. 支持表单项visibleIf属性动态设置是否可见;
  8. 支持获取表单项context并在运行时设置属性;

一个简单的示例

我们通过创建一个简单的示例项目来告诉大家如何使用v-formly。

安装脚手架工具(已安装可忽略)

$ npm install -g @vue/cli 
# OR 
$ yarn global add @vue/cli

创建一个项目

使用命令行进行初始化。

$ vue create antd-demo

并配置项目。

若安装缓慢报错,可尝试用 cnpm 或别的镜像源自行安装:rm -rf node_modules && cnpm install

安装ant-design-vue 1.x

$ npm i --save ant-design-vue@1.7.8

安装v-formly

使用yarn安装yarn add v-formly或者使用npm安装npm i v-formly --save,然后在你的main.js入口文件添加如下内容:

import Vue from 'vue';
import App from './App';
import Antd from 'ant-design-vue';
import 'ant-design-vue/dist/antd.css';
import VFormly from "v-formly";

Vue.config.productionTip = false

Vue.use(Antd);
Vue.use(VFormly);

new Vue({
render: h => h(App),
}).$mount('#app')

使用v-formly创建表单

打开App.vue文件,删除里面的内容,复制下面的代码进去并保存。

<template>
  <div id="app">
    <div class="wrapper">
      <v-formly ref="form" v-model="data" :meta="meta"> </v-formly>
      <div class="btns">
        <a-button type="danger" @click="clear"> 重置 </a-button>
        <a-button type="primary" @click="submit"> 提交 </a-button>
      </div>
    </div>
  </div>
</template>

<script>
export default {
  name: "App",
  data: function () {
    return {
      meta: {
        type: "object",
        properties: {
          name: {
            title: "姓名",
            type: "string",
            default: "kevin",
            ui: {
              showRequired: true,
            },
          },
          desc: {
            title: "描述",
            type: "string",
            default: "Base on technical, but not limited on it!",
            ui: {
              change: (val) => {
                console.log("val = ", val);
              },
            },
          },
          enable: {
            title: "启用",
            type: "boolean",
          },
        },
        required: ["name"],
      },
      data: { enable: true },
    };
  },
  methods: {
    clear() {
      this.data = null;
    },
    async submit() {
      let valid = await this.$refs.form.validate();
      if (valid) {
        this.$message.success(JSON.stringify(this.data));
      }
    },
  },
};
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #2c3e50;
  margin-top: 60px;
}
.wrapper {
  margin: auto;
  max-width: 600px;
}
.btns {
  display: flex;
  justify-content: flex-end;
}
.ant-btn + .ant-btn {
  margin-left: 8px;
}
</style>

此时,你已经完成了一个简单的使用v-formly的项目了,这是运行yarn serve或者npm run serve,浏览器中会看到一个简单的表单如下所示:
在这里插入图片描述

打开控制台,点击“提交”按钮,你会看到提交的表单数据,非常简单!(PS:如果此时没有看到这个页面,请参考在线示例查找问题)

针对上述示例我们做以下几点解释

  1. v-formly 支持 v-model 双向绑定,可通过修改 data 来随时改变 form 表单数据;

  2. 传入的 metaJSON-Schema结构 + 嵌套ui的组合,v-formly 使用 meta 来解析并渲染表单页面;

  3. 以上表单包括两个string类型和一个boolean类型的内置component.
    a. 其中name为必填项(required: ["name"]体现出来),且默认内容为“kevin”,其中ui.showRequired为 true 会添加 label 前面的红色星号;

    b. desc非必填,默认内容为“Base on technical, but not limited on it!”,且提供了 change 事件,当输入改变时触发;

    c. enable为一个简单的 AntDv 的Switch组件。

通过上述简单的表单示例,我们大概了解了如何开始使用 v-formly,接下来我们介绍一下v-formly实现的主要功能点。

支持使用JSON定义表单结构

v-formly正是使用了JSON来定义表单结构才达到了不用画UI的效果,使你在快速创建完表单之后可以快速编写业务逻辑。举例说明,我们的表单需要一个输入框来输入姓名,则定义如下meta传入v-formly即可。

{
    "type": "object",
    "properties": {
        "name": {
            "title": "姓名",
            "type": "string",
            "default": "kevin",
            "ui": {
                "showRequired": true
            }
        }
    },
    "required": [
        "name"
    ]
}

此时生成界面如下:
在这里插入图片描述
上面的JSON结构定义了label为“姓名”的string类型的输入框,并且是必填的,默认内容为“kevin”,其中required为Ajv可识别的内置校验,此时删除输入框中的内容点击提交,则会校验不通过。ui为v-formly中的自定义节点,非JSON Schema的标准节点,此节点下面几乎同步了ant design vue组件的所有属性,部分不同可参考组件showRequired会在label前面添加一个红色的*号代表必填,无校验逻辑。

此时如果我们在ui下面增加一个ant design vue组件的属性prefix如下,

{
    "type": "object",
    "properties": {
        "name": {
            "title": "姓名",
            "type": "string",
            "default": "kevin",
            "ui": {
                "showRequired": true,
                "prefix": "$"
            }
        }
    },
    "required": [
        "name"
    ]
}

则生成如下页面:

在这里插入图片描述

看到了吗,非常简单!

支持水平垂直行内三种布局

v-formly支持这三种布局,可以很好的满足大部分业务需求,水平垂直的布局适合创建表单或者编辑表单,行内布局适合列表页查询表单等。

我们通过传入layout来实现各种布局(layout = horizontal | vertical | inline)。

这个非常直观就不多介绍了,可参考布局示例

支持Ajv内置的校验以及自定义数据校验(同步校验和异步校验)

Ajv内置的校验请参考属性说明,这里分类列出了各种类型的校验属性。

自定义校验我们支持同步校验和异步校验。

  1. 同步校验

如下meta结构中,我们在ui节点下增加了validator属性,此属性接收一个函数,参数为当前表单项的值,并返回一个错误消息数组,数组中的keyword为Ajv的标准关键字,这样我们就能够知道是什么错误,message为自定义错误消息(此处,当val不存在时会报错)。

meta: {
  type: "object",
  properties: {
    name: {
      title: "姓名",
      type: "string",
      default: "kevin",
      ui: {
        showRequired: true,
        validator: (val) => !val ? [{ keyword: "required", message: "Required name" }] : [],
      },
    },
  },
  required: ["name"],
},

在这里插入图片描述

  1. 异步校验

异步校验类似,只不过返回的是一个Promise

meta: {
  type: "object",
  properties: {
    asyncError: {
    title: "异步错误(2秒)",
    type: "string",
    ui: {
    showRequired: true,
    validatorAsync: (val) => {
    return new Promise((resolve) => {
    setTimeout(() => {
        resolve(
            !val ? [{ keyword: "required", message: "Required asyncError",}] : []
        );
    }, 2000);
    });
    },
    },
    },
  },
  required: ["asyncError"],
},

如需更多了解,请参考文档自定义校验

支持自定义表单提交按钮以及内置提交按钮

v-formly可以在外部自定义提交按钮,也可以使用v-formly的内置按钮,使用内置按钮则必须实现重置和提交事件。具体内容请参考表单

支持表单项visibleIf属性动态设置是否可见

在表单中会经常出现当某个表单项的值发生改变时,另一个表单项隐藏或出现的逻辑,这里我们就可以使用visibleIf属性。

{
	type: "object",
	properties: {
		string1: {
			title: "字段二是否可见",
			type: "string",
			ui: {
				showRequired: true,
				placeholder: "当值为v-formly时字段二可见",
				errors: {
					required: "请输入",
				},
				change: (val) => console.log(val),
			},
		},
		string2: {
			title: "字段二",
			type: "string",
			ui: {
				showRequired: true,
				show: false,
				visibleIf: {
					"/string1": (context, id, val) => {
						return val === "v-formly";
					},
				},
			},
		},
	},
	required: ["string1", "string2"],
}

此案例中,只有第一个输入框的值为“v-formly”的时候,第二个输入框才会出现。

支持获取表单项context并在运行时设置属性

v-formly还支持运行时动态获取context,从而可以动态修改表单项的各种参数属性等。

const context = this.$refs.form.getContext("/multiple");
if (context) {
    context.ui.options = ["上", "右", "下", "左"];
    context.value = "下";
}

详情请参考Radio 单选框“设置规格”按钮示例

好了,到了这里大家对v-formly都有了一个大概的了解,大家可以自己使用一下v-formly库,也希望大家能够提出宝贵的意见和建议,帮助我更好维护和优化v-formly!

再一次:github地址在这里文档在这里!觉得对你有帮助就给个star吧!

PS: vue 3 & ant design vue 3.x 正在开发中,Comming soon!

PS: v-formly的英文文档目前缺失中,如果有兴趣可以提PR哦!

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-10-31 11:46:33  更:2022-10-31 11:48:43 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 17:47:46-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码