1
我正在嘗試編寫一個簡單的Flask API來讀取字段name
,email
,phone
,message
與POST,驗證它們,並根據驗證的輸出返回true或false - 以下JS腳本。我怎樣才能做到這一點?如何使用Flask在客戶端驗證表單?
@app.route('/email' , methods = ['POST'])
def email():
name = request.form["name"]
phone = request.form["phone"]
email = request.form["email"]
message = request.form["message"]
return json.dumps({'status' : 'OK' , 'name' : name , 'phone' : phone , 'email' : email , 'message' : message});
。
$(function() {
$("input,textarea").jqBootstrapValidation({
preventSubmit: true,
submitError: function($form, event, errors) {
// additional error messages or events
},
submitSuccess: function($form, event) {
// event.preventDefault(); // prevent default submit behaviour
// get values from FORM
var name = $("input#name").val();
var email = $("input#email").val();
var phone = $("input#phone").val();
var message = $("textarea#message").val();
var firstName = name; // For Success/Failure Message
// Check for white space in name for Success/Fail message
if (firstName.indexOf(' ') >= 0) {
firstName = name.split(' ').slice(0, -1).join(' ');
}
$.ajax({
url: "/email",
data: $('form').serialize(),
type: "POST",
cache: false,
success: function() {
// Success message
$('#success').html("<div class='alert alert-success'>");
$('#success > .alert-success').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>×")
.append("</button>");
$('#success > .alert-success')
.append("<strong>Your message has been sent. </strong>");
$('#success > .alert-success')
.append('</div>');
//clear all fields
$('#contactForm').trigger("reset");
},
error: function() {
// Fail message
$('#success').html("<div class='alert alert-danger'>");
$('#success > .alert-danger').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>×")
.append("</button>");
$('#success > .alert-danger').append("<strong>Sorry " + firstName + ", it seems that my mail server is not responding. Please try again later!");
$('#success > .alert-danger').append('</div>');
//clear all fields
$('#contactForm').trigger("reset");
},
})
},
filter: function() {
return $(this).is(":visible");
},
});
$("a[data-toggle=\"tab\"]").click(function(e) {
e.preventDefault();
$(this).tab("show");
});
});
/*When clicking on Full hide fail/success boxes */
$('#name').focus(function() {
$('#success').html('');
});
爲了完成問題提出的問題,我們是否可以從發佈的JSON創建一個WTForms對象,檢查WTForms對象是否會驗證,並返回'true'或'false'爲JSON? – Monkpit
@KylePittman我認爲這是可能的,但我不確定這是管理數據的正確方法。但即使在這種情況下,驗證將在服務器端執行,而不是客戶端,因爲它被詢問。 – wanderlust
好的一點,我認爲在這種情況下,「客戶端驗證」意味着在表單實際提交之前給用戶反饋,但事實並非如此。 – Monkpit