Bat*_*kun 6 html javascript python ajax flask
我正在尝试制作一个动态表单生成器。在构建过程之后,我试图通过脚本将所有表单数据放入 JsonObject 并将其传递给烧瓶视图,以便我可以将它们显示给用户。但我无法正确设置。这是调用javascript的按钮
<form action="/preview" method="post" role="form">
<button class="btn btn-primary" name = "submit" id = "submit">submit</button>
</form>
Run Code Online (Sandbox Code Playgroud)
这是我进行 ajax 调用的脚本。
<script>
$(document).ready( function() {
$('#submit').click(function() {
var formdata = serialize();
$.ajax({
type: 'POST',
contentType: 'application/json',
data: JSON.stringify(formdata),
dataType: 'json',
url: 'http://192.168.58.206:5000/index',
success: function (e) {
console.log(e);
},
error: function(error) {
console.log(error);
}
});
});
});
</script>
Run Code Online (Sandbox Code Playgroud)
这是我尝试在flask python中渲染的方式。
@app.route('/', methods=['GET', 'POST'])
@app.route('/index', methods=['GET', 'POST'])
def index():
if request.method == 'POST':
asd = request.json
session['formdata'] = asd
if 'formdata' in session:
return json.dumps({'success': True}), 200, {'ContentType': 'application/json'}
return render_template("index.html")
@app.route('/preview', methods=['GET', 'POST'])
def preview():
if 'formdata' in session:
renderedform = formbuilder(json.dumps(session['formdata']))
renderedform = renderedform.renderform()
session.pop('formdata')
return render_template("asd.html",renderform = renderedform)
return "Error"
Run Code Online (Sandbox Code Playgroud)
我的 renderdorm() 方法将 json 对象作为参数并为表单创建相应的 html 块。
但是当我以这种方式运行它时,有时按钮操作会在脚本运行并创建 json 对象之前将我定向到 /preview 路由。所以这会导致会话的表单数据为无。
任何想法如何传递该 json 对象以在预览中呈现?
您需要删除表单上的操作字段,因为当用户单击按钮操作时,可能未设置称为会话的操作
<form method="post" role="form">
<button class="btn btn-primary" name = "submit" id = "submit">submit</button>
</form>
Run Code Online (Sandbox Code Playgroud)
然后在 ajax 上,您需要在成功时设置为窗口位置
<script>
$(document).ready( function() {
$('#submit').click(function() {
var formdata = serialize();
$.ajax({
type: 'POST',
contentType: 'application/json',
data: JSON.stringify(formdata),
dataType: 'json',
url: 'http://192.168.57.223:5000/createform',
success: function (e) {
console.log(e);
window.location = "http://192.168.57.223:5000/preview";
},
error: function(error) {
console.log(error);
}
});
});
});
</script>
Run Code Online (Sandbox Code Playgroud)
那么你的python脚本应该看起来像这样你需要说你接受了这个值并且ajax会设置所需的窗口位置
@app.route('/index', methods=['GET', 'POST'])
def index():
if request.method == 'POST':
asd = request.json
print(asd)
session['formdata'] = asd
if 'formdata' in session:
return json.dumps({'success': True}), 200, {'ContentType': 'application/json'}
return render_template("createform.html")
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9097 次 |
| 最近记录: |