form表单
- form表单已经集成了快速验证以及提交的方法,无需手动重组数据再进行提交
- 默认提交的数据是提交当前
url
,如需提交到其它页面,修改一下lay-submit
的值即可 - 在对应的js文件内引入
easy-admin
模块,并执行ea.listen();
进行监听
必填值
使用
lay-verify="required"
,会自动生成必填小红点, 并且会在提交的时候进行必填验证
<div class="layui-form-item">
<label class="layui-form-label">权限名称</label>
<div class="layui-input-block">
<input type="text" name="title" class="layui-input" lay-verify="required" placeholder="请输入权限名称" value="">
<tip>填写权限名称。</tip>
</div>
</div>
lay-submit
事件监听
使用该事件监听,会自动获取表单数据以POST
方式自动提交。
与
lay-submit
事件监听的相关参数:
参数 | 说明 | 类型 | 是否必填 | 默认 | 备注 |
---|---|---|---|---|---|
lay-submit | 监听表单自动提交 | string | 是 | 当前地址 | 为空则提交的当前地址。如果需要提交到其它地址,此处填写对应的地址。 |
data-refresh | 提交成功后是否需要刷新 | bool | 否 | true | 提交成功后,关闭弹出层,刷新 父层的table列表 ,如果不需要刷新,或者没有用到弹出层,此处改为false |
lay-filter | layui内置过滤器 | string | 否 | 自动生成唯一值 | 无特殊需求,此处无需填写,会自动生成 |
例子
<div class="layui-form-item text-center">
<button type="submit" class="layui-btn layui-btn-normal layui-btn-sm" lay-submit>确认</button>
<button type="reset" class="layui-btn layui-btn-primary layui-btn-sm">重置</button>
</div>
提交前置操作
事件监听方法:
ea.listen(preposeCallback, ok, no, ex)
,可能用得比较多的还是preposeCallback
的提交前置回调。
参数 | 说明 | 类型 | 是否必填 | 备注 |
---|---|---|---|---|
preposeCallback | 表单提交前的前置回调 | function | 否 | 一般用于需要重新组装一些特殊的数据再提交 |
ok | 提交成功后的回调 | function | 否 | |
no | 提交失败后的回调 | function | 否 | |
ex | 提交异常后的回调 | function | 否 |
ea.listen(function (data) {
// 此处进行数据重组再返回
data.test = '测试重组数据';
return data;
});
完整例子
<div class="layuimini-container">
<form id="app-form" class="layui-form layuimini-form">
<div class="layui-form-item">
<label class="layui-form-label">权限名称</label>
<div class="layui-input-block">
<input type="text" name="title" class="layui-input" lay-verify="required" placeholder="请输入权限名称" value="">
<tip>填写权限名称。</tip>
</div>
</div>
<div class="layui-form-item layui-form-text">
<label class="layui-form-label">备注信息</label>
<div class="layui-input-block">
<textarea name="remark" class="layui-textarea" placeholder="请输入备注信息"></textarea>
</div>
</div>
<div class="hr-line"></div>
<div class="layui-form-item text-center">
<button type="submit" class="layui-btn layui-btn-normal layui-btn-sm" lay-submit>确认</button>
<button type="reset" class="layui-btn layui-btn-primary layui-btn-sm">重置</button>
</div>
</form>
</div>