Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/fangkyi03/nextjs-antd-dva-form-demo

dva form表单演示
https://github.com/fangkyi03/nextjs-antd-dva-form-demo

antd dva fast form

Last synced: about 2 months ago
JSON representation

dva form表单演示

Awesome Lists containing this project

README

        

# 高性能表单框架

1.整体场景演示的demo 主要对标uform的所有demo 后续uform其他的demo 将会在之后逐步添加

# 新增功能
```javascript
1.新增 场景 - 常用场景
2.新增 性能演示 - 1000个编辑框
3.新增 性能演示 - 2000个编辑框
4.新增 性能演示 - 8000个编辑框
5.新增 动态表单 演示
6.新增 动态表单 事件绑定
```

# 安装
```javascript
cnpm i
```

# 运行
```javascript
npm run dev
```

# 页面数据源隔离
```javascript
通过如下的这种方式:
createDva(modelNameList)(FormView)
你其实就做到了一个简单的隔离 你的FormView现在只会跟demo5Form这个model进行绑定
这个页面的值修改不会再影响到外层页面的刷新
所以这个时候你想刷新demo5Form这个model的时候 只需要调用
api.setValue(thz,'demo5Form',{xxx})
就会修改对应model的值
这个api在下面有介绍
```

# modelName优先级
```javascript
默认modelName取值优先级:
createDva > props
constructor(props) {
super(props);
this.form = createDva(['demo5Form'])(FormView)
}
render() {
const Form = this.form
return (



{this.renderButtonGroup()}

)
}
如上面这个场景
当你formView使用createDva包裹以后
即时formView的props中有modelName 也会优先使用createDva中使用的值
createDva并不是必须的只有如动态表单或者想通过props去刷新的时候 才应该使用这个 其他情况无需包裹
直接如下使用即可

```

# 与dva官方DEMO的差异
```javascript
我对dva的model做了简化处理 你只需要调用以下两个api即可修改任意model

通过createDva就等于注册了一个model 任何操作都可以通过下面两个api实现
// 获取指定model值
api.getValue(this,modelName) : object
// 设置指定model值
api.setValue(this,modelName,params)
无需学习saga也不需要有redux的开发经验 变得很简单

```

# 项目结构介绍
```
总体分为三个
1.formStore
(用于处理整个系统的所有表单所有行为 包括错误处理 赋值等) 需要手动销毁数据 等于redux的store
2.FormContainer
整个项目所有的表单容器类
3.formModel
整个系统所有表单的外层控制器 内部调用formStore中的函数
主要用于从外层发起action修改formStore
相比直接每个页面引入一次formStore会来的更加干净
```

# api介绍

```javascript
// 使用刷新props的方式来刷新页面
setValue
使用:
setValue(this,modelName,params) : void
```
```javascript
// 获取当前页面路由参数
getRouterParams
使用:
getRouterParams(this) : object
```

```javascript
// vw 转换函数
getSize
使用:
getSize():string
```

```javascript
// 控制弹出窗口显示
toggleModal
使用:
toggleModal(this,modelName,isShow) : void
```

```javascript
// 强制打开页面并且设置当前modal为编辑模式
openEditModal
使用:
openEditModal(this,modelName,isEdit) : void
```

```javascript
// 清空指定表单数据 因表单数据绑定在store中 默认不会删除数据 主要你主动删除
clearForm
使用:
clearForm(this,modelName) : void
```

```javascript
// 控制表单中子项是否显示 这个控制的是一行row的整体显示
// 一行中单个组件的显示控制 将会有另外一个函数 敬请期待
setFormNotDisplay
使用:
setFormNotDisplay(this,modelName,notDisplay = []) : void
```

```javascript
// 修改指定表单的数据源
setFormValue
使用:
setFormValue(this,modelName,data : object) : void
```
```javascript
// 返回指定表单数据
// 隐居对应传入的值返回对应的结构
getFormValue
使用:
getFormValue(this,modelName,key : array | string | undefined) : promise
```

```javascript
// 表单效验提交 如果错误
sumbitForm
使用:
sumbitForm(this,modelName,callBack:({error:object | null,data:object | null})) : void
```

```javascript
// 重置表单内容 这里只重置数据源里面有数据的表单组件 其余一改不参与
// 比如你有1W个组件 你刚才只改了一个组件 那么你点击重置的时候 只会重置这一个组件
resetForm
使用:
resetForm(this,modelName):void
```

# 备注说明
因项目使用的是next的关系 部分页面打开会出现样式丢失的情况 这个只需要重新刷新一下即可

# 未来工作
- [] 完成imgCook的vscode插件编写 实现私有化部署 已立项完成了部分功能
- [] 实现用babel将web转换为taro代码 主要面向公众号网页