0

我正在尝试在我的网络应用程序中使用 PureCSS 表单,但我不知道如何在停止页面重新加载时保留漂亮的表单验证。

我知道我可以使用停止页面重新加载onsubmit="return false;"

然后我可以使用 AJAX 发布表单数据onClick="PostSettings();",其中 PostSettings() 是我的包含 AJAX 请求的 javascript 函数。我还必须event.preventDefault();在该函数的顶部包含以停止重新加载。

不幸的是,这些停止重新加载的步骤也停止了内置的 PureCSS 验证。

有没有办法在不触发页面重新加载的情况下保留它,或者我需要在 javascript 中进行自己的验证?

仅供参考,这是html:

<button type="submit" class="pure-button pure-input-1-2 pure-button-primary"
  id="save-simulation-button" onClick="PostSettings();" 
  onsubmit="return false;">
    <i     class="fa fa-save"></i> Submit Simulation Parameters
</button>
4

4 回答 4

0

在“PostSettings()”方法中使用“return false”而不是 event.preventDefault()。

于 2016-01-11T16:44:00.743 回答
0

感谢您的回复 Lucas 和 Vignesh - 他们并没有完全解决问题,但他们让我思考并开发了一个解决方案:

在 html 中,我必须在这里添加一个返回:onClick="return PostSettings();"

然后在javascript中我返回truefalse取决于表单是否通过验证,我必须检查:

function PostSettings() {
    //event.preventDefault(); <<- commented out per Vigneshs suggestion

    var name = $("#simulation-name").val(); // jquery to get form values
    var description = $("#description").val();

    // Code to validate form: name and description cannot be blank
    if (name === "" || description === "") {
        console.log("name or description fields cannot be blank");
        return true; // <<- returning true allows PureCSS validation to continue
    }

    // Code passed validation so post the data...
    // POST code omitted for brevity

    return false; // <<- returning false stops the page reload
}

所以总而言之,返回true允许 PureCSS 表单验证正常进行(并且没有页面重新加载,因为表单尚未通过验证)。当表单通过验证时,我返回false以停止页面重新加载——这也停止了 PureCSS 表单的任何其他默认事件,但这没关系,因为我手动检查了它是否在 javascript 中验证。

希望这可以帮助其他想要在未来实现这一目标的人!

于 2016-01-11T19:23:21.467 回答
0

你只需要一个onsubmit="return MyValidFunction();" 在表单标签中,在“提交”按钮中没有其他内容

当表单不正确时,PureCSS 使用他的消息进行验证,当一切正常时,调用您的“MyValidFunction()”函数

function MyFunction() {
   /// your Ajax Code here
   return false;
}

<form class="pure-form" onsubmit="return PostSettings();">
  <input id="form_url" type="url" class="pure-input-1-3">
   <button type="submit" class="pure-button pure-input-1-1">OK</button>
</form>
于 2016-03-28T05:52:40.577 回答
0

我遇到过同样的问题。添加onsubmit="event.stopPropagation()"表单标签可防止表单有效时刷新,并在表单无效时保留验证标志。

于 2018-03-06T05:38:56.920 回答