使用preventdefault后我无法提交表单

问题描述 投票:0回答:1

我在模态结构中有一个表单,在该表单中,我从用户那里收集了一些信息,之后我想将该信息提交到发布请求中,以便我可以在python中处理它,问题是,我需要首先检查是否用户实际上把信息,所以我不会得到空值。我正在使用.preventDefault()来停止提交并检查值。只要我不使用preventDefault,该程序就可以正常发布,并且在使用它时实际上不发布,问题是在通过所有条件后,它应该发布,但没有这样做,我也不知道为什么。

这是表格的代码:

<form id="forminout" action="/in_out" method="post">
        <div class="modal fade bd-example-modal-lg" tabindex="-1" role="dialog" id="incomeModal">
            <div class="modal-dialog modal-lg" role="document">
                <div class="modal-content">
                    <div class="modal-header">
                        <h5 class="modal-title">Add your new income</h5>
                        <button type="button" class="close" data-dismiss="modal" aria-label="Close">
                             <span aria-hidden="true">&times;</span>
                        </button>
                    </div>
                    <div class="modal-body" id="new_incomes">
                        <div style="padding:3%">
                            <input step=".01" type="number" class="form-control input-sm" name="incoming" min="0" placeholder="0">
                            <select class="incomselect" name="incomeselects" style="height:30px;">
                                <option selected disabled>This income is coming from?</option>
                                <option value="rent">Rents</option>
                                <option value="salary">Salary</option>
                                <option value="invest_reveneu">Investments reveneus</option>
                                <option value="others">Others</option>
                            </select>
                            <select class="incomdate" name="incomedate" style="height: 30px;">
                                <option selected disabled>Incoming date</option>
                                <option value=5>1 - 5</option>
                                <option value=10>6 - 10</option>
                                <option value=15>11 - 15</option>
                                <option value=20>16 - 20</option>
                                <option value=25>21 - 25</option>
                                <option value=31>26 - 31</option>
                            </select>
                        </div>
                    </div>
                    <div class="modal-footer">
                        <button class="btn btn-primary" id="addinbutt" type="submit">Save changes</button>
                        <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
                    </div>
                </div>
            </div>
        </div>
   </form>

这很好,因为该帖子实际上正在发生。

这是邮寄请求的“简化”代码:

$("document").ready(function(){
    $("form").on("submit", function(e){
        errors = 0;
        e.preventDefault();
        if (errors==0)
        {
            document.getElementById("#forminout").submit();
        }
    })
})

在这种情况下,errors == 0条件仅用于简化,假设我需要检查的所有实际条件都可以。

我无法发布

javascript html forms preventdefault
1个回答
0
投票

解决方案:写this.submit()e.target.submit()而不是doc.getElById().submit()

© www.soinside.com 2019 - 2024. All rights reserved.