- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
从下面的第一个屏幕截图中,我有一个 Flask 应用程序,它有一个搜索字段,该字段使用 Ajax 请求来查询美国州列表以作为下拉值返回。当我离开Name
字段为空并点击提交,这无意中删除了我之前选择的下拉值。我也想在表单验证期间保留下拉字段。
app.py
import sys
from flask import Flask, render_template, request
from forms import InputForm
app = Flask(__name__)
app.config['SECRET_KEY'] = "Development"
US_STATES = ["Alaska", "Alabama", "Arkansas", "American Samoa", "Arizona", "California",
"Colorado", "Connecticut", "District ", "of Columbia", "Delaware",
"Florida", "Georgia", "Guam", "Hawaii", "Iowa", "Idaho", "Illinois",
"Indiana", "Kansas", "Kentucky", "Louisiana", "Massachusetts", "Maryland",
"Maine", "Michigan", "Minnesota", "Missouri", "Mississippi", "Montana",
"North Carolina", "North Dakota", "Nebraska", "New Hampshire",
"New Jersey", "New Mexico", "Nevada", "New York", "Ohio", "Oklahoma",
"Oregon", "Pennsylvania", "Puerto Rico", "Rhode Island", "South Carolina",
"South Dakota", "Tennessee", "Texas", "Utah", "Virginia", "Virgin Islands",
"Vermont", "Washington", "Wisconsin", "West Virginia", "Wyoming"]
@app.route("/", methods=["GET","POST"])
def index():
form = InputForm()
if request.method == "POST":
print(form.name.data, file=sys.stderr)
print(form.states.data, file=sys.stderr)
print(form.territory.data, file=sys.stderr)
print("Hello from outside Validate.", file=sys.stderr)
if form.validate_on_submit():
print(form.name.data, file=sys.stderr)
print(form.states.data, file=sys.stderr)
print(form.territory.data, file=sys.stderr)
print("Hello from inside Validate.", file=sys.stderr)
else:
print(form.errors)
return render_template("states.html", form=form)
@app.route("/search")
def search():
text = request.args["searchText"]
result = [c for c in US_STATES if text.lower() in c.lower()]
return {"results": result}
if __name__ == '__main__':
app.run(host="localhost", port=5001, debug=True)
forms.py
from flask_wtf import FlaskForm
from wtforms import StringField, SelectField, SubmitField
from wtforms import validators
from wtforms.validators import Optional, InputRequired, DataRequired
class InputForm(FlaskForm):
name = StringField("Name", validators=[DataRequired()])
states = SelectField("US States", validate_choice=False)
territory = SelectField("Is Territory?", choices=["Unknown", "Yes", "No"], default="Unknown", validators=[InputRequired()])
submit = SubmitField("Add State", validators=[Optional()])
模板\index.html
<!DOCTYPE html>
<html>
<head>
<title>Live Search Ajax Demo</title>
<meta charset="utf-8" />
<!-- CSS Stylesheets -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.0-beta3/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-eOJMYsd53ii+scO/bJGFsiCZc+5NDVN2yr8+0RDqr0Ql0h+rP48ckxlpbzKgwra6" crossorigin="anonymous">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.12.1/css/bootstrap-select.css"/>
<script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.12.1/js/bootstrap-select.js"></script>
<script type="text/javascript">
function liveSearch(value) {
value = value.trim();
if (value != "") {
$.ajax({
url: "search",
data: { searchText: value },
dataType: "json",
success: function (data) {
var res = "";
for (i in data.results) {
res += "<option value=" + data.results[i] + ">" + data.results[i] + "</option>";
}
$("#states").html(res);
},
});
} else {
$("#states").html("");
}
}
</script>
</head>
<body>
<!-- Main -->
<main role="main" class="container">
<div>
{% block content %}
{% endblock %}
</div>
</main>
</body>
</html>
模板\states.html
{% extends "index.html" %}
{% block content %}
<div class="content-section">
<div class="col-6">
<div class="row mt-4 mb-4">
<h2>Live Search in Flask with Ajax</h2>
<hr>
<div class="row mt-4 mb-4">
<form method="POST" action="" novalidate="novalidate">
{{ form.hidden_tag() }}
<fieldset class="form-group">
<div class="row">
<div class="col">
{{ form.name.label(class="form-control-label") }}
{% if form.name.errors %}
{{ form.name(class="form-control form-control-md is-invalid") }}
<div class="invalid-feedback">
{% for error in form.name.errors %}
<span>{{ error }}</span>
{% endfor %}
</div>
{% else %}
{{ form.name(class="form-control form-control-md") }}
{% endif %}
</div>
<div class="col">
{{ form.territory.label(class="form-control-label") }}
{% if form.territory.errors %}
{{ form.territory(class="form-control form-control-md is-invalid") }}
<div class="invalid-feedback">
{% for error in form.territory.errors %}
<span>{{ error }}</span>
{% endfor %}
</div>
{% else %}
{{ form.territory(class="form-control form-select") }}
{% endif %}
</div>
</div>
<div class="row">
<div class="input-group mt-4 mb-4">
<input type="text" class="form-control" placeholder="Search USA States" onkeyup="liveSearch(this.value)">
{{ form.states(class="form-control form-select") }}
</input>
</div>
</div>
<div class="input-group mb-3 justify-content-md-end">
<div class="form-group">
{{ form.submit(class="btn btn-primary btn-sm") }}
</div>
</div>
</fieldset>
</form>
</div>
</div>
</div>
{% endblock content %}
最佳答案
JQuery official documentation如果您需要某些东西,非常适合初学者,我建议您从那里开始。
否则,请清楚地说明您要做什么。
这是一种更简洁的方法来完成您已经完成的工作。
确保您的表单内容具有非常严格的规则(我认为您可以在后端的“表单构建器”上自定义此规则),例如:
<input name="Name" type="text" maxlength="10" required />
$(document).ready(function () {
$('#inputSearchStates').keyup(function () { // when a keyboard key is hitted (even CTRL is included and all keyboard keys...)
var value = $(this).val().trim(); // remove first and last blank spaces from your string (note that blank spaces in the middle will still remain)
if (this.form.reportValidity()) { // return true if the form is valid (required inputs already filled ...etc)
$.ajax({
url: "search",
data: {
searchText: value
},
dataType: "json",
success: function (data) {
// data is the returned result from your backend
// it can be a string/filled array/empty array/number/float ...etc
$("#states").empty(); // always make your dropdown empty (with definitely no options to select)
data.results.each(function () { // automatically fetch the response result (a JS array) if exists , else it will do nothing.
$("#states").append(`
<option value="${this}"> ${this} </option>
`); // for each available data in your response result and append <options> respectively
});
// remember that your dropdown will still empty if no data there is no data in your response array.
},
});
}
});
});
关于Javascript:表单验证导致选定的 Ajax Live Search 字段被重置为 Null?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67472739/
我有一个“设置首选项”屏幕。它有一个 ListPreference 和一个 CheckBoxPreference。当我选择 ListPreference 的一项时,我想更改应用程序的日期格式。另外,通
我试图找到创 build 置/配置窗口的示例。单击菜单项中的“选项”操作可启动设置窗口。我想弄清楚如何从主窗口打开第二个窗口。以及新窗口如何将设置信息返回主窗口。尝试使用 QDialog 或一些继承的
我在 Lnux 上有 Qt 应用程序。我想为此创建一个可执行文件/设置以便在 Windows 上分发它并且不需要安装 Qt。我通过包含所有 dll 为此创建了可执行文件但要运行它,用户需要进入文件夹。
我正在尝试创建一个有点动态的 html 类,它根据类末尾包含的数字设置宽度 %。注意:类名将始终以“gallery-item-”开头 示例:div.gallery-item-20 = 20% 宽度 我
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 6 年前。 Improve this qu
在我的应用程序中,我想记住一些变量,例如,如果用户登录过一次,那么他们将在下次重新打开应用程序时登录,或者如果他们决定禁用某些提醒,应用程序可以检查该变量是否是错误的,将不再显示该提醒。理想情况下,这
我在 Netbeans 中开发了一个应用程序,它连接到远程计算机的消息队列并发送消息。该应用程序还有其他功能。项目完成后,我清理并构建应用程序,然后 Netbeans 创建一个 jar 文件。 但我的
我创建了一个 Outlook 加载项,需要创建一个设置以使其可分发(我是新手,所以请原谅新手评论) Outlook -2010 Vs -2010 .Net 4.0 我读了一些地方,最简单的方法就是发
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: How to make installer pack of Java swing Application Proje
这个问题肯定已经被很多人解决过很多次了,但是经过几个小时的研究,我仍然没有找到我要找的东西。 我有一个 ExportSettings.settings 文件,其中包含一堆设置( bool 值、字符串、
我想为我的项目创建一个安装程序,以便它可以安装在任何电脑上而无需安装头文件。我怎样才能做到这一点? 最佳答案 一般有两种分发程序的方法: 源代码分发(要构建的源代码)。最常见的方法是使用 GNU au
如何在这样的动态壁纸中创 build 置 Activity ? Example Picture 我只用一个简单的文本构建了设置 Activity ,但遇到了一些问题。第一个问题是我不能为此 Activ
我用 GUI 创建了一个简单的软件。它有几个源文件。我可以在我的编辑器中运行该项目。我认为它已经为 1.0 版本做好了准备。但我不知道如何为我的软件创 build 置/安装程序。 源代码是python
我的 SettingsActivity当前扩展了 Android Studio 生成的类,AppCompatPreferenceActivity扩展 PreferenceActivity . Acti
我正在使用 .NET 为 IE 开发工具栏。目前,我使用 gacutil 插入我的 .NET 程序集,并使用 regasm 注册我的 COM 程序集。 我想为项目创建一个设置 (MSI),但我似乎无法
在为设置页面创建 Activity 后,我注意到 if (mCurrentValue !== value) 中的 mCurrentValue !== value 返回警告: Identity equa
我在 Visual Studio 10 中创建了一个项目,该项目使用 Mysql 数据库和 Crystalreports 以及 它。但是我不知道如何进行自动安装 Mysql 和 Crystalrepo
我正在尝试在我的 C# 项目中使用 Sqlite 数据库,并且我在 IDE 中做得很好。我的问题是当我为我的项目制作安装包并安装它时,程序无法访问 sqlite 数据库。我也知道这是因为用户没有访问文
我有一个大型 Web 应用程序(带有 11 子系统的 ErP),我想使用 Microsoft WebPI 为它创建一个设置。 目前,我们每周向客户发送一次应用程序(用于每周更新)。 我们在此应用程序中
所以我对工资单申请的最终查询是 - 如何为薪资申请创 build 置? 我需要知道的一切- 如何将设置项目添加到我现有的解决方案 如何将解决方案中的文件添加到安装项目中,以及添加哪些文件添加和在什么文
我是一名优秀的程序员,十分优秀!