当用户输入可创建重复项的值时,我需要在Google App Engine中设置警报弹出窗口。这样做的最佳方式是什么?
我找到了一种方法,但它远非优雅:
当用户输入重复的项目代码时,我会显示一个新页面" error-message.html"这解释了用户发生了什么,并提供了一个"返回"按钮。但是,我宁愿在" add-project.html"上显示警告。页。 Javascript是个好主意但它无法在数据库中验证,因此没有用。
GAE / Python中显示从代码触发的警告框的最佳做法是什么?
所以任何帮助或建议都将不胜感激!
谢谢!
CODE:
我现在正在处理的应用是一个简单的项目经理工具。我使用GAE附带的webapp2。
当前工作流程: 1)在AddProject中,我向用户显示一个输入新项目数据的页面(" add-project.html)。此页面基于JINJA模板。用户填写数据并点击提交。 2)提交调用SaveAddedProject,如果项目代码已经存在,则检查NDB。 3)如果项目代码尚未在NDB中,则新项目将保存在NDB中,代码将重定向到常规项目页面。 4)如果项目存在,我会显示一个名为" error-message.html"的新页面。告诉用户他/她正在输入重复值并提供返回的按钮。然后,用户可以更改其值并重试。
型号:
class Project(ndb.Model):
# Models and individual Project entry
proj_id = ndb.StringProperty(required = True)
proj_desc = ndb.StringProperty(required = True)
proj_status = ndb.StringProperty(required = True)
调度程序:
class AddProject(webapp2.RequestHandler):
# Displays template to fill-in data for new project,
# then calls SaveAddedProject
def post(self):
user = users.get_current_user() # We use Google's login system
logout_url = users.create_logout_url(self.request.url)
template_values = {
'user_id': user,
'logout_url': logout_url,
}
template = JINJA_ENVIRONMENT.get_template('add-project.html')
self.response.write(template.render(template_values))
class SaveAddedProject(webapp2.RequestHandler):
# Saves a new project. Is called from AddProject
def post(self):
proj_id_str = self.request.get('proj_id')
proj_desc_str = self.request.get('proj_desc')
proj_status_str = self.request.get('proj_status')
# The add template already validates required fields aren't empty :-)
# Verify we don't duplicate the project_id
pq = Project.query(ancestor = get_projects_key())
pq = pq.filter(Project.proj_id == proj_id_str)
pq_result = pq.fetch(limit=1)
if len(pq_result) > 0: # Notify the user
template_values = {'error_message': 'Project ID ' + proj_id_str + ' already exists',
}
template = JINJA_ENVIRONMENT.get_template('error-message.html')
self.response.write(template.render(template_values))
else:
# Create new project
project = Project(parent=get_projects_key()) # Use root ancestor key
# Populate fields, save to NDB
project.proj_id = proj_id_str
project.proj_desc = proj_desc_str
project.proj_status = proj_status_str
project.put()
self.redirect('/projects')
add-project.html的HTML:
<!DOCTYPE html>
{% autoescape true %}
<html>
<head>
<link type="text/css" rel="stylesheet" href="/stylesheets/pages.css" />
<title>Action List</title>
<script>
function validateForm() {
var count = 0;
var x = document.forms["form1"]["proj_id"].value;
if (x == null || x == "") {
count = 1;
}
var x = document.forms["form1"]["proj_desc"].value;
if (x == null || x == "") {
count = 1;
}
if (count == 1) {
document.getElementById('AlertMsg').innerHTML = '<font color="red">Please fill in all fields marked with *</font>';
return false;
}
}
</script>
</head>
<body>
<h2>Add Project</h2>
<br>
<b>User: {{ user_id }} </b>
<br><br>
<form name="form1" action="/p-save-add" onsubmit="return validateForm()" method="post">
<div>
ID * <input value="" name="proj_id" size="15">
Description * <input value="" name="proj_desc" size="50">
Status: <select name='proj_status'>
<option value='Open'>Open</option>
<option value='Closed'>Closed</option>
</select>
</div>
<br>
<div><input type="submit" value="Save"></div>
</form>
<br>
<br>
<b id='AlertMsg' > </b>
</body>
</html>
{% endautoescape %}
HTML for error-message.html:
<!DOCTYPE html>
{% autoescape true %}
<script>
function goBack() {
window.history.back();
}
</script>
<html>
<head>
<title>ActionList</title>
<link type="text/css" rel="stylesheet" href="/stylesheets/messages.css" />
</head>
<body>
<h3> Sorry, an error ocurred!</h3>
{{ error_message }}
<br>
<br>
<button onclick="goBack()">Back</button>
</body>
{%endautoescape%}
答案 0 :(得分:1)
您应该使用这两种方法。您只需显示错误页面的方法是从安全角度处理问题的正确方法(验证需要在服务器上进行,因为表单可以通过绕过JavaScript中的验证的方式提交)以及兼容性透视图(浏览器可能会禁用JavaScript并在没有它的情况下访问您的表单)。
但是,从用户体验的角度来看,最好在与表单相同的页面上获取验证错误,而不必导航到某个新页面只是为了查看错误(并且必须再次填写表单)。请注意,即使您的验证检查必须在服务器上进行,您仍然可以通过JavaScript在UI中进行此验证;您可以使用XMLHttpRequest在JavaScript中提交表单,以便您的JavaScript代码能够查看/处理响应。然后,您可以将响应消息指示为各种可能的错误之一。
例如,查看“反馈”机制如何在my website上运行;你会注意到有一个版本的表格没有JavaScript(“/ feedback”页面),但如果你启用了JavaScript,按钮实际上会在JavaScript中打开一个对话框,使用XMLHttpRequest提交表单,如果表单无法提交,错误直接在对话框中报告,无需导航到新页面(通过读取响应的状态代码或查看服务器返回的JSON响应中包含的详细错误消息)。 p>