会话在 python 代码中设置。我使用烧瓶作为框架。会话用户名值保持不变,直到用户重新加载页面。如果有办法用 javascript 响应会话值的变化或重新加载必要的部分而不重新加载整个页面?谢谢。
索引.html:
<div id="cform">
<form action="" method="get">
<div class="cl">{{ session['username'] }}$ >
<input type="text" class="cli" name="cmd"
autocomplete='off' value="" autofocus />
</div>
</form>
</div>
<script type=text/javascript>
$(function () {
$('form').last().submit(function () {
$.getJSON($SCRIPT_ROOT + '/_cmd', {
cmd: $('input[name="cmd"]').last().val()
}, function (data) {
var $query = $('input[name="cmd"]').last().val();
$("<span>{{ session['username'] }}$ > " + $query + "</span><br />").appendTo("#output");
$(data).each(function (i, val) {
$.each(val, function (k, v) {
$("<span>" + v + "</span><br />").appendTo("#output");
});
});
$("#output").append($("form"));
$("form input").val("").focus();
});
return false;
});
});
</script>
<div id="output"></div>
索引.py:
@app.route('/')
def index():
if 'username' in session:
username = escape(session['username'])
else:
session['username'] = 'guest'
return render_template('index.html')
@app.route('/_cmd')
def cmd():
cmd = request.args.get('cmd')
interpreter = Interpreter(cmd)
output = interpreter.mediator()
return jsonify(output)