Skip to content

form表单

  • form表单已经集成了快速验证以及提交的方法,无需手动重组数据再进行提交
  • 默认提交的数据是提交当前url,如需提交到其它页面,修改一下lay-submit的值即可
  • 在对应的js文件内引入easy-admin模块,并执行ea.listen();进行监听

必填值

使用lay-verify="required",会自动生成必填小红点, 并且会在提交的时候进行必填验证

html
        <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提交成功后是否需要刷新booltrue提交成功后,关闭弹出层,刷新父层的table列表,如果不需要刷新,或者没有用到弹出层,此处改为false
lay-filterlayui内置过滤器string自动生成唯一值无特殊需求,此处无需填写,会自动生成

例子

html
        <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
js
ea.listen(function (data) {
    
    // 此处进行数据重组再返回
    data.test = '测试重组数据';
    
   return data;
});

完整例子

html
<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>