同一个页面提交多个form表单方法

办法1.同一个页面中建立两个表单 各自提交:

<form action="?" name="form1" id="form1"> <!-- 表单内容 --> <input type="submit" /> </form> <form action="?" name="form1" id="form1"> <!-- 表单内容 --> <input type="submit" /> </form>

 

 

 

 

===========================================================

 

办法2:如果非要只有一个表单的话,通过js提交:

<script type="text/javascript" language="javascript"> function submitYouFrom(path){ $('form1').action=path; $('form1').submit(); } </script> <form action="?" name="form1" id="form1"> <!-- 表单内容 --> <script type="text/javascript" language="javascript"> function submitYouFrom(path){ $('form1').action=path; $('form1').submit(); } </script> <form action="?" name="form1" id="form1"> <!-- 表单内容 --> <input type="button" value="提交1" οnclick="submitYouFrom('地址一')"/> <input type="button" value="提交2" οnclick="submitYouFrom('地址二')"/> </form>

 

 

===========================================================

 

方法3:

function submitYouFrom(mets,path){ $("#form1").attr("action",path); $("#form1").attr("method",mets); $('#form1').submit(); } submitYouFrom('方式',‘路径');

 

 

 

 

 

===========================================================

方法4:一个按钮同时提交两个表单

 

<script type="text/javascript">

function go(){

var targetUrl = $("#tenementForm").attr("action");

var data = $("#tenementForm").serialize();

$.ajax({

type:'post',

url:targetUrl,

data:data,

dataType:'json',

error:function(){

alert("出错")

}

,

success:function(data){

alert(data.msg);

if(data.code==1){

document.getElementById("recordForm").submit();

}

 

}

})

}

</script>

 

<body>

<form action="/zxbs/tenement/update" id="tenementForm" method="post">

***

</form>

<form action="/zxbs/record/update" id="recordForm" method="post" >

***

</form>

<button type="button" οnclick="go()">保存</button>

</body>

 

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 layui 的提交监听函数来实现多个提交一个的效果。 首先,给每个需要提交设置一个唯一的 id,然后在页面加载完成后,使用 layui 的 form.on() 方法监听提交事件,当任意一个提交时,获取该的数据并存储到一个全局变量中,然后阻止提交。当最后一个提交时,将存储的所有数据合并,然后使用 ajax 提交数据并清空存储的数据。 示例代码如下: HTML: ```html <!-- 1 --> <form class="layui-form" id="form1"> <div class="layui-form-item"> <label class="layui-form-label">用户名</label> <div class="layui-input-block"> <input type="text" name="username" required lay-verify="required" placeholder="请输入用户名" autocomplete="off" class="layui-input"> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">密码</label> <div class="layui-input-block"> <input type="password" name="password" required lay-verify="required" placeholder="请输入密码" autocomplete="off" class="layui-input"> </div> </div> <div class="layui-form-item"> <div class="layui-input-block"> <button class="layui-btn" lay-submit lay-filter="form1">提交</button> </div> </div> </form> <!-- 2 --> <form class="layui-form" id="form2"> <div class="layui-form-item"> <label class="layui-form-label">姓名</label> <div class="layui-input-block"> <input type="text" name="name" required lay-verify="required" placeholder="请输入姓名" autocomplete="off" class="layui-input"> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">年龄</label> <div class="layui-input-block"> <input type="number" name="age" required lay-verify="required" placeholder="请输入年龄" autocomplete="off" class="layui-input"> </div> </div> <div class="layui-form-item"> <div class="layui-input-block"> <button class="layui-btn" lay-submit lay-filter="form2">提交</button> </div> </div> </form> ``` JavaScript: ```javascript // 定义一个全局变量,用于存储所有数据 var formData = {}; // 监听提交事件 layui.form.on('submit', function(data){ // 获取 id 和数据 var id = data.form.attr('id'); var data = data.field; // 将数据存储到全局变量中 formData[id] = data; // 如果不是最后一个提交,则阻止提交 if (Object.keys(formData).length < 2) { return false; } // 合并所有数据 var allData = {}; for (var key in formData) { allData = Object.assign(allData, formData[key]); } // 使用 ajax 提交数据 $.ajax({ url: 'http://example.com/submit', type: 'POST', data: allData, success: function(){ // 清空全局变量 formData = {}; // 提示用户提交成功 layer.msg('提交成功'); }, error: function(){ // 提示用户提交失败 layer.msg('提交失败,请重试'); } }); }); ``` 在上面的代码中,我们使用了 Object.keys() 方法来获取 formData 对象中属性的数量,然后判断当前提交是否为最后一个。如果不是最后一个,则阻止提交。最后一个提交时,我们使用 Object.assign() 方法将所有数据合并为一个对象,然后使用 ajax 提交数据。在提交成功或失败后,我们清空 formData 对象并提示用户。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值