为什么我的表格在'背面'按钮

Why my form submits on a 'back' button?

本文关键字:背面 按钮 我的 表格 为什么      更新时间:2023-09-26

我有一个表单,它由7个单独显示的输入字段组成,其中"下一个按钮"用于显示下一个输入并隐藏当前输入,"后退按钮"用于隐藏当前输入并显示上一个输入。问题是,当我点击"后退按钮"时,最后一次输入的提交函数会运行,它会将未完成的字段保存在数据库中。我不知道为什么以及如何防止它。下面是"后退按钮"的示例代码:

Template.submitProblem.events({
  'click .back1':function() {
    //show/hide items with removeClass()/addClass()
    $('#submit-why1').addClass('hidden');
    $('#submit-problem').removeClass('hidden');
  }
});

以及最后一个输入字段上的提交功能:

Template.submitProblem.events({
  'submit form':function(event) {
    event.preventDefault();
    var problem = $(event.target).find('[name=problem]').val();
    var why1 = $(event.target).find('[name=why1]').val();
    var why2 = $(event.target).find('[name=why2]').val();
    var why3 = $(event.target).find('[name=why3]').val();
    var why4 = $(event.target).find('[name=why4]').val();
    var why5 = $(event.target).find('[name=why5]').val();
    var solution = $(event.target).find('[name=solution]').val();
   Problems.insert({
      problem: problem,
      why1: why1,
      why2: why2,
      why3: why3,
      why4: why4,
      why5: why5,
      solution: solution,
      submitdate: new Date()
    });
    Router.go('submitted');
  }
});

<template name="submitProblem">
  <div class="container">
    <div class="main-page">
      <form class="form text-center">
        <div id="submit-problem">
          <input autofocus="autofocus" type="text" name="problem" id="problem" placeholder="What's the problem ?"/>
          <input type="button" id="route" value="Find Its Route" class="route btn btn-sample">
        </div>
        <div id="submit-why1" class="hidden">
          <input autofocus="autofocus" type="text" name="why1" id="why1" placeholder="This problem exists, because..."/>
          <input type="button" value="Answer" class="btn-success btn answer1">
          <div>
          <button class="btn back1 back-btn"><i class="fa fa-arrow-left fa-3x"></i></button>
          </div>
        </div>
        ...

您应该始终为<button>元素指定type属性,因为不同的浏览器可能会为<button>元素使用不同的默认类型。在您的情况下,您需要更新您的后退按钮以具有类型按钮,这样它就不会提交。

<button type="button" class="btn back1 back-btn"><i class="fa fa-arrow-left fa-3x"></i></button>