提交第二个表单时阻止第一个表单提交

时间:2016-07-08 05:04:33

标签: php jquery html forms laravel-5

这是交易(使用php和laravel-5.2) 我在页面中有一些forms,当我提交another form而不是第一个时,它会继续提交first form
这是我的HTML代码:

<form method="POST" action="http://localhost:8888/candidates/18" accept-charset="UTF-8" id="name-edit" style="display:none">
     <input name="_method" type="hidden" value="PUT">
     <input name="_token" type="hidden" value="xxzvu6HIqP8k2kg78pxuHiTc8NWftjNL1IJvxbDo">
     <div  class="form-group ">
         <div  class="col-xs-12 col-sm-5 ">
             <input placeholder="Full Name" error="" id="name-input" class="width-100" name="name" type="text" value="chi qua uqaaa1232">
         </div>
     </div>
     <button class="green btn-link col-xs-4" type="submit"><i class="ace-icon glyphicon glyphicon-ok"></i> Click to save or press Enter</button>
</form>

<form method="POST" action="http://localhost:8888/candidates/18" accept-charset="UTF-8" id="address-edit" style="display:none">
     <input name="_method" type="hidden" value="PUT">
     <input name="_token" type="hidden" value="xxzvu6HIqP8k2kg78pxuHiTc8NWftjNL1IJvxbDo">
     <div class="form-group ">
          <div class="col-xs-12 col-sm-5 ">
               <input placeholder="Address" error="" id="address-input" class="width-100" name="address" type="text" value="nha xacdawdwad">
          </div>
     </div>
     <button class="green btn-link col-xs-4" type="submit"><i class="ace-icon glyphicon glyphicon-ok"></i> Click to save or press Enter</button>
</form>

我的两种表单的jquery代码:

$(document).ready(function(){
    $("#name-edit").focusout(function() {
        $('#name-edit').css('display', 'none');
        $('#name-view').css('display', 'inline');
    });

    $("#address-edit").focusout(function() {
        $('#address-edit').css('display', 'none');
        $('#address-view').css('display', 'inline');
    });
});

$('#btn-edit-name').click(function () {
    var name = $('#name-view').css('display', 'none').clone().children().remove().end().text();
    $('#name-input').val(name);
    $('#name-edit').css('display', 'inline').focus();
});

$('#btn-edit-address').click(function () {
    var name = $('#address-view').css('display', 'none').clone().children().remove().end().text();
    $('#address-input').val(name);
    $('#address-edit').css('display', 'inline').focus();
});

btn-edit-namebtn-edit-address用于显示表单。谢谢你的考虑。
这是我的用户界面:
enter image description here

3 个答案:

答案 0 :(得分:1)

  

您不能同时提交2份表格。

您可以将其添加到单个表单中,而不是使用2个名称和地址字段表单:

<form method="POST" action="http://localhost:8888/candidates/18" accept-charset="UTF-8" id="name-edit" style="display:none">
     <input name="_method" type="hidden" value="PUT">
     <input name="_token" type="hidden" value="xxzvu6HIqP8k2kg78pxuHiTc8NWftjNL1IJvxbDo">
     <div  class="form-group ">
         <div  class="col-xs-12 col-sm-5 ">
             <input placeholder="Full Name" error="" id="name-input" class="width-100" name="name" type="text" value="chi qua uqaaa1232">
         </div>
     </div>
     <div class="form-group ">
        <div class="col-xs-12 col-sm-5 ">
           <input placeholder="Address" error="" id="address-input" class="width-100" name="address" type="text" value="nha xacdawdwad">
        </div>
     </div>
     <button class="green btn-link col-xs-4" type="submit"><i class="ace-icon glyphicon glyphicon-ok"></i> Click to save or press Enter</button>
</form>

如果您希望在点击时显示隐藏它们,那么您可以添加一些jQuery来执行此操作。

答案 1 :(得分:0)

您可以有两种不同的操作

action="http://localhost:8888/candidates/18"

action="http://localhost:8888/candidates/19" 

如果不可能,为每个表单添加不同的隐藏输入,如

在表格1中添加此行

 <input type="hidden" name="identifier" value="form1">

在表格2中添加此行

<input type="hidden" name="identifier" value="form2">

现在您可以使用if ($_POST['identifier'] == 'form1')

OR

您也可以使用switch语句

switch($_POST['identifier']){
    case 'form1':{}
    case 'form2':{}
}

此外,您的两个提交按钮完全相同。您可以为提交后可以检查的每个设置一个值。设置这样的值 表格1名称

<button class="green btn-link col-xs-4" type="submit" value="name" name="name"><i class="ace-icon glyphicon glyphicon-ok"></i> Click to save or press Enter</button>

表格2地址

<button class="green btn-link col-xs-4" type="submit" value="address" name="address"><i class="ace-icon glyphicon glyphicon-ok"></i> Click to save or press Enter</button>

答案 2 :(得分:0)

哦,我找到的答案是将type提交按钮设置为button,然后为点击事件jquery设置$(this).closest('form').submit()

相关问题